[
  {
    "context": [
      "Any ideas on how to make \"less\" keep the colors?",
      "jq -C \".\" /tmp/myfile.json | less -R",
      "You can force it to produce color even if writing to a pipe or a file using -C, and disable color with -M"
    ],
    "utterance": "Display colored output when viewing the results in less after piping the output.",
    "expressions": [
      "jq -C '.' /tmp/myfile.json | less -R"
    ],
    "identifier": 62809196
  },
  {
    "context": [
      "I\u2019m having trouble removing double quotes from the date I pass in to JQ.",
      "Use `tonumber`. You need to use parentheses not to change the context for the remaining elements of the array.",
      "[($date | tonumber), .totalTimeSpent, .totalRecords, .totalDuplicates]"
    ],
    "utterance": "Output an array containing the provided date as a number (without double quotes), totalTimeSpent, totalRecords, and totalDuplicates from the payload.overallStatus object.",
    "expressions": [
      "[($date | tonumber), .totalTimeSpent, .totalRecords, .totalDuplicates]"
    ],
    "identifier": 62824080
  },
  {
    "context": [
      "How can I return the whole JSON after filtering inner array elements of a top-level key?",
      "I need to filter `annotations` where `category_id` has one of several values, for example `1, 2`.",
      "but how can I return the entire original JSON after filtering the specified category ids?",
      "Here is the solution which uses the `|=` operator which modifies an element in place.",
      "jq '.annotations |= map(select(.category_id | contains(1,2)))' instances_val2017.json",
      "jq '.annotations |= map(select(.category_id == (1,2)))' instances_val2017.json"
    ],
    "utterance": "Return the entire top-level object but with the annotations array filtered to include only elements where category_id is 1 or 2.",
    "expressions": [
      ".annotations |= map(select(.category_id == 1 or .category_id == 2))",
      ".annotations |= map(select(.category_id == (1,2)))",
      ".annotations |= map(select(.category_id | contains(1,2)))"
    ],
    "identifier": 62839937
  },
  {
    "context": [
      "test_cases=($(jq -c '.[]' data.json))",
      "readarray -t test_cases < <(jq -c '.[]' file)",
      "IFS=$'\\n' read -d '' -a test_cases < <(jq -c '.[]' file)",
      "readarray -t test_cases < <(jq -c '.[]' data.json)",
      "while IFS= read -r line; do\n    test_cases+=(\"$line\")\ndone < <(jq -c '.[]' data.json)"
    ],
    "utterance": "Extract each top-level array element as a compact string, preserving all whitespace within string fields such as CREATED_DATE containing spaces.",
    "expressions": [
      ".[]",
      "-c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "USERID": "TMCCP",
            "CREATED_DATE": "31/01/2020 17:52"
          },
          {
            "USERID": "TMCCP",
            "CREATED_DATE": "31/01/2020 17:52"
          }
        ],
        "output": [
          "{\"USERID\":\"TMCCP\",\"CREATED_DATE\":\"31/01/2020 17:52\"}",
          "{\"USERID\":\"TMCCP\",\"CREATED_DATE\":\"31/01/2020 17:52\"}"
        ]
      }
    ],
    "identifier": 62815281
  },
  {
    "context": [
      "I want to return an array that only contains the id (first property of the object) IF the *owner* property is 12345.",
      "To select *accounts* whose *owner*'s *id* is `12345`, and extract their (*account*'s, not *owner*'s) *id*s, you can use this one:",
      "$ jq '.accounts | map(select(.owner.id == 12345) .id)' file",
      "Another option could be",
      ".accounts[]| select(.owner.id == 12345).id"
    ],
    "utterance": "Return an array of account ids where the owner id is 12345.",
    "expressions": [
      ".accounts | map(select(.owner.id == 12345) .id)",
      ".accounts[] | select(.owner.id == 12345) | .id"
    ],
    "data": [
      {
        "input": {
          "accounts": [
            {
              "id": 1234,
              "name": "Sample Name",
              "status": "upgraded",
              "subscription": {
                "id": 4567,
                "products": [
                  {
                    "product_id": 5,
                    "name": "Awesome Product",
                    "units": 1,
                    "price": 1
                  },
                  {
                    "product_id": 1,
                    "name": "Another Awesome Product",
                    "units": 1,
                    "price": 1
                  }
                ]
              },
              "owner": {
                "id": 12345,
                "email": "email@email.com",
                "first_name": "John",
                "last_name": "Doe",
                "state": "active"
              }
            },
            {
              "id": 2345,
              "name": "Other Name",
              "status": "basic",
              "subscription": {
                "id": 5678,
                "products": []
              },
              "owner": {
                "id": 67890,
                "email": "someone@other.com",
                "first_name": "Jane",
                "last_name": "Smith",
                "state": "active"
              }
            }
          ]
        },
        "output": [
          1234
        ]
      }
    ],
    "identifier": 62819335
  },
  {
    "context": [
      "I want to transform it to is:\r\n\r\n```\r\n{\t\r\n\tsubcategories\r\n\t[\r\n\t\t{&quot;id&quot;: &quot;1&quot;,&quot;val&quot;: &quot;blue&quot;}\r\n\t\t{&quot;id&quot;: &quot;2&quot;,&quot;val&quot;: &quot;red&quot;}\r\n\t]\r\n\r\n}\r\n```",
      "or, if you only want to retain the \"id\" and \"val\" keys:\r\n```\r\n{subcategories: .category.subcategory | map({id,val}) }\r\n```"
    ],
    "utterance": "Construct an object with a subcategories array, each containing only the id and val fields from category.subcategory.",
    "expressions": [
      "{subcategories: .category.subcategory | map({id,val}) }"
    ],
    "data": [
      {
        "input": {
          "category": {
            "subcategory": [
              {
                "id": "1",
                "val": "blue",
                "foo": "blahblah",
                "bar": "blahblah"
              },
              {
                "id": "2",
                "val": "red",
                "foo": "blahblah",
                "bar": "blahblah"
              }
            ]
          }
        },
        "output": {
          "subcategories": [
            {
              "id": "1",
              "val": "blue"
            },
            {
              "id": "2",
              "val": "red"
            }
          ]
        }
      }
    ],
    "identifier": 62842963
  },
  {
    "context": [
      "But how to get the output which matched both first and last name?",
      ".users |= map(select(\n  (.first == \"Stevie\") and (.last == \"Wonder\")\n))",
      ".users |= map(select(\n    (.first == \"Stevie\") and (.last == \"Wonder\")\n  ))\n| .users[].birthday",
      "\"01/01/1945\""
    ],
    "utterance": "Return the birthday where first name is \"Stevie\" and last name is \"Wonder\".",
    "expressions": [
      ".users[] | select((.first == \"Stevie\") and (.last == \"Wonder\")) | .birthday",
      ".users |= map(select((.first == \"Stevie\") and (.last == \"Wonder\"))) | .users[].birthday"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "first": "Stevie",
              "last": "Wonder",
              "birthday": "01/01/1945"
            },
            {
              "first": "Michael",
              "last": "Jackson",
              "birthday": "03/23/1963"
            }
          ]
        },
        "output": "01/01/1945"
      }
    ],
    "identifier": 62870293
  },
  {
    "context": [
      "I want to take the id which has matchers.value as dev-stack and status.state as active",
      ".data |= map(select(\n  (.matchers | any(.value==\"dev-stack\")) and (.status.state==\"active\")\n))"
    ],
    "utterance": "Return the ids where any matcher value is dev-stack and status state is active",
    "expressions": [
      ".data[] | select((.matchers | any(.value == \"dev-stack\")) and (.status.state == \"active\")) | .id"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": [
            {
              "id": "b5e7f85d",
              "matchers": [
                {
                  "name": "stack",
                  "value": "dev-stack",
                  "isRegex": true
                }
              ],
              "startsAt": "2020-07-13T07:17:36Z",
              "endsAt": "2020-07-15T07:15:44Z",
              "updatedAt": "2020-07-13T07:15:59.643692023Z",
              "createdBy": "api",
              "comment": "Silence",
              "status": {
                "state": "active"
              }
            },
            {
              "id": "1fdaa4b5",
              "matchers": [
                {
                  "name": "stack",
                  "value": "qa-stack",
                  "isRegex": true
                }
              ],
              "startsAt": "2020-07-10T13:19:12Z",
              "endsAt": "2020-07-10T13:20:55.510739499Z",
              "updatedAt": "2020-07-10T13:20:55.510739499Z",
              "createdBy": "api",
              "comment": "Silence",
              "status": {
                "state": "expired"
              }
            }
          ]
        },
        "output": [
          "b5e7f85d"
        ]
      }
    ],
    "identifier": 62871446
  },
  {
    "context": [
      "I\u2019m passing a JSON object to jq and want to add extra objects to an inner array (\u2018accessories\u2019) if its parent array (\u2018platforms\u2019) matches a certain name.",
      "but of course it\u2019s poor form to expect platforms[1] to always the be array I want to append to, so I set about trying to form the right syntax for a search or if/then/else to only act on the .name of the appropriate one.",
      "The key here is to use the `select()` function to identify the object you are going to update and overwrite the overall array using `|=` operator, i.e.\n\n    .platforms |= ( map(select(.name == \"CBus\").accessories += [{ \"values\" : \"NEW\" }]  ) )"
    ],
    "utterance": "Add an object {\"values\": \"NEW\"} to the accessories array of each object in platforms whose name is \"CBus\".",
    "expressions": [
      ".platforms |= (map(select(.name == \"CBus\").accessories += [{\"values\": \"NEW\"}]))"
    ],
    "data": [
      {
        "input": {
          "bridge": {
            "name": "Homebridge",
            "port": 51395
          },
          "accessories": [],
          "platforms": [
            {
              "name": "Config",
              "port": 8581,
              "platform": "config"
            },
            {
              "platform": "homebridge-cbus.CBus",
              "name": "CBus",
              "client_ip_address": "127.0.0.1",
              "accessories": [
                {
                  "values": "existing"
                }
              ]
            }
          ]
        },
        "output": {
          "bridge": {
            "name": "Homebridge",
            "port": 51395
          },
          "accessories": [],
          "platforms": [
            {
              "name": "Config",
              "port": 8581,
              "platform": "config"
            },
            {
              "platform": "homebridge-cbus.CBus",
              "name": "CBus",
              "client_ip_address": "127.0.0.1",
              "accessories": [
                {
                  "values": "existing"
                },
                {
                  "values": "NEW"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 62875625
  },
  {
    "context": [
      "I want to remove they key `b` of the object modules.",
      "But this fails when the `parents` array is present. I get \n\n> Cannot index array with string \"b\"\n\nHow can I make the command ignore the parents array and only work on the modules object?",
      "You need to do\n\n    with_entries( select(.key == \"modules\").value |= del(.b) )\n\nThe `select()` function filters that object keyed by name `\"modules\"` and applies the delete action on that object alone."
    ],
    "utterance": "Remove the key 'b' from the 'modules' object, leaving other top-level keys unchanged even if they are arrays.",
    "expressions": [
      "with_entries(select(.key == \"modules\").value |= del(.b))"
    ],
    "data": [
      {
        "input": {
          "parents": [
            {
              "id": 1,
              "name": "X"
            }
          ],
          "modules": {
            "a": 1,
            "b": 2
          }
        },
        "output": {
          "parents": [
            {
              "id": 1,
              "name": "X"
            }
          ],
          "modules": {
            "a": 1
          }
        }
      }
    ],
    "identifier": 62893671
  },
  {
    "context": [
      "I am trying to extract the sessionkey from the records using jq. Is there a generic way to match both cases:",
      "Sample #1: message with multiple records:",
      "Sample #2: message with a single record:",
      "If it is acceptable to print all \"sessionKey\" values, then the simplest would probably be:",
      "```\n.. | objects | select(has(\"sessionKey\")) | .sessionKey\n```"
    ],
    "utterance": "Extract all values for the field sessionKey, whether meetingUsageHistory is an array or a single object.",
    "expressions": [
      ".. | objects | select(has(\"sessionKey\")) | .sessionKey"
    ],
    "data": [
      {
        "input": {
          "message": {
            "header": {
              "response": {
                "result": "SUCCESS",
                "gsbStatus": "PRIMARY"
              }
            },
            "body": {
              "bodyContent": {
                "type": "history:lstmeetingusageHistoryResponse",
                "meetingUsageHistory": [
                  {
                    "sessionKey": "1263859083"
                  },
                  {
                    "sessionKey": "623922696"
                  }
                ],
                "matchingRecords": {
                  "total": "2",
                  "returned": "2",
                  "startFrom": "1"
                }
              }
            }
          }
        },
        "output": [
          "1263859083",
          "623922696"
        ]
      },
      {
        "input": {
          "message": {
            "header": {
              "response": {
                "result": "SUCCESS",
                "gsbStatus": "PRIMARY"
              }
            },
            "body": {
              "bodyContent": {
                "type": "history:lstmeetingusageHistoryResponse",
                "meetingUsageHistory": {
                  "sessionKey": "297115075"
                },
                "matchingRecords": {
                  "total": "1",
                  "returned": "1",
                  "startFrom": "1"
                }
              }
            }
          }
        },
        "output": [
          "297115075"
        ]
      }
    ],
    "identifier": 62826775
  },
  {
    "context": [
      "Requirement: I want to grep or extract from the output satisfying a condition. <br> Condition: status == 200 <br> Output: The respective output should contain all urls which has a status 200, considering the below example, the output has to be ```https://www.example.com/newfuzz```",
      "jq -r '.results[] | select(.status == 200).url'"
    ],
    "utterance": "Extract all url values where status is 200.",
    "expressions": [
      ".results[] | select(.status == 200) | .url",
      ".results[] | select(.status == 200).url"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "input": {
                "FUZZ": "fuzzerhere"
              },
              "position": 53,
              "status": 403,
              "length": 670,
              "words": 105,
              "lines": 9,
              "redirectlocation": "",
              "resultfile": "",
              "url": "https://www.example.com/fuzzerhere",
              "host": "www.example.com"
            },
            {
              "input": {
                "FUZZ": "newfuzz"
              },
              "position": 53,
              "status": 200,
              "length": 670,
              "words": 105,
              "lines": 9,
              "redirectlocation": "",
              "resultfile": "",
              "url": "https://www.example.com/newfuzz",
              "host": "www.example.com"
            }
          ]
        },
        "output": "https://www.example.com/newfuzz"
      }
    ],
    "identifier": 62907100
  },
  {
    "context": [
      "I need to split large files (`~5G`) of JSON data into smaller files with [newline-delimited JSON][1] in a memory efficient way (i.e., without having to read the entire JSON blob into memory). The JSON data in each source file is an array of objects.",
      "I\u2019m able to achieve the desired result by using [`jq`][2] and `split` ...",
      "cat large_source_file.json \\\n  | jq -cn --stream 'fromstream(1|truncate_stream(inputs))' \\\n  | split --line-bytes=1m --numeric-suffixes - split_output_file",
      "Here are some performance benchmarks ... # using jq ... time cat ${SOURCE_FILE} \\\n  | jq -cn --stream 'fromstream(1|truncate_stream(inputs))' \\\n  | split --line-bytes=1m - split_output_file\nreal\t2m0.656s\nuser\t1m58.265s\nsys\t    0m6.126s",
      "jq's *streaming* parser (the one invoked with the --stream command-line option) intentionally sacrifices speed for the sake of reduced memory requirements",
      "For the task at hand (streaming the top-level items of an array):\n... \njq --stream:      2 MB   447\n...",
      "In words:\n\n1. `space`: jstream is economical with memory, but not as much as jq's streaming parser.\n\n2. `time`: jstream runs slightly slower than jq's regular parser but about 4 times faster than jq's streaming parser."
    ],
    "utterance": "Split a very large file containing an array of objects into smaller files, each with one object per line, in a memory-efficient way without loading the entire data into memory.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "foo"
          },
          {
            "id": 2,
            "name": "bar"
          },
          {
            "id": 3,
            "name": "baz"
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "foo"
          },
          {
            "id": 2,
            "name": "bar"
          },
          {
            "id": 3,
            "name": "baz"
          }
        ]
      }
    ],
    "identifier": 62825963
  },
  {
    "context": [
      "The fields I need are:",
      "userIdentity.userName",
      "eventTime",
      "awsRegion",
      "sourceIPAddress",
      "responseElements.ConsoleLogin",
      "eventID",
      "jq '.userIdentity.userName, .eventTime, .awsRegion, .sourceIPAddress, .responseElements.ConsoleLogin, .eventID'"
    ],
    "utterance": "Extract the values of userIdentity.userName, eventTime, awsRegion, sourceIPAddress, responseElements.ConsoleLogin, and eventID as separate outputs from each event object.",
    "expressions": [
      ".userIdentity.userName, .eventTime, .awsRegion, .sourceIPAddress, .responseElements.ConsoleLogin, .eventID"
    ],
    "data": [
      {
        "input": {
          "eventVersion": "x.xx",
          "userIdentity": {
            "type": "xxxxxxxxxx",
            "principalId": "xxxxxxxxxx",
            "arn": "xxxxxxxxxx",
            "accountId": "xxxxxxxxxx",
            "userName": "xxxxxxxxxx"
          },
          "eventTime": "2020-07-15T08:50:35Z",
          "eventSource": "signin.amazonaws.com",
          "eventName": "ConsoleLogin",
          "awsRegion": "xxxxxxxxxx",
          "sourceIPAddress": "xxxxxxxxxx",
          "userAgent": "xxxxxxxxxx",
          "requestParameters": null,
          "responseElements": {
            "ConsoleLogin": "Success"
          },
          "additionalEventData": {
            "LoginTo": "xxxxxxxxxx",
            "MobileVersion": "xxxxxxxxxx",
            "MFAUsed": "xxxxxxxxxx"
          },
          "eventID": "xxxxxxxxxx",
          "eventType": "xxxxxxxxxx",
          "recipientAccountId": "xxxxxxxxxx"
        },
        "output": [
          "xxxxxxxxxx",
          "2020-07-15T08:50:35Z",
          "xxxxxxxxxx",
          "xxxxxxxxxx",
          "Success",
          "xxxxxxxxxx"
        ]
      }
    ],
    "identifier": 62913414
  },
  {
    "context": [
      "The string needs to be split at each \\n and the substrings \"^\\n?-\\s\" of each resulting array element need to be removed.",
      "it should result in:\r\n\r\n{\r\n\t\"entryId\": 1,\r\n\t\"description\": [\"item 1\", \"item 2\", \"item 3\"]\r\n}",
      "An alternate version using `split()` on the `\\n` and trimming string `- ` on the left, would be to do\n\n    .[].stuff.properties.stuff_list[].description |= \n      if . != null then \n        split(\"\\n\") | map(ltrimstr(\"- \")) \n      else \n        . \n      end"
    ],
    "utterance": "For each 'description' value, split the text at newline and remove the initial '- ' prefix from each resulting item, leaving 'description' as an array; skip if value is null.",
    "expressions": [
      ".[].stuff.properties.stuff_list[].description |= if . != null then split(\"\\n\") | map(ltrimstr(\"- \")) else . end"
    ],
    "data": [
      {
        "input": [
          {
            "name": "test 1",
            "stuff": {
              "properties": {
                "id": 0,
                "stuff_list": [
                  {
                    "entryId": 1,
                    "description": "- item 1\n- item 2\n- item 3"
                  },
                  {
                    "entryId": 2,
                    "description": "- item 1\n- item 2\n- item 3"
                  }
                ]
              }
            }
          },
          {
            "name": "test 2",
            "stuff": {
              "properties": {
                "id": 1,
                "stuff_list": [
                  {
                    "entryId": 1,
                    "description": null
                  },
                  {
                    "entryId": 2,
                    "description": "- item 1\n- item 2\n- item 3"
                  }
                ]
              }
            }
          }
        ],
        "output": [
          {
            "name": "test 1",
            "stuff": {
              "properties": {
                "id": 0,
                "stuff_list": [
                  {
                    "entryId": 1,
                    "description": [
                      "item 1",
                      "item 2",
                      "item 3"
                    ]
                  },
                  {
                    "entryId": 2,
                    "description": [
                      "item 1",
                      "item 2",
                      "item 3"
                    ]
                  }
                ]
              }
            }
          },
          {
            "name": "test 2",
            "stuff": {
              "properties": {
                "id": 1,
                "stuff_list": [
                  {
                    "entryId": 1,
                    "description": null
                  },
                  {
                    "entryId": 2,
                    "description": [
                      "item 1",
                      "item 2",
                      "item 3"
                    ]
                  }
                ]
              }
            }
          }
        ]
      }
    ],
    "identifier": 62911272
  },
  {
    "context": [
      "Looking to extract values from api_http array. I am looking for output that looks like the following. Each element should have the name and the url value attached a key called api.",
      "Try:\r\n\r\n    .report.api_http[]|{name:values[0][\"name\"],api:values[1]}",
      "You could use the -c command-line option in conjunction with the following jq filter:\r\n```\r\n.report.api_http[]\r\n| {name: .[0].name, api: .[1]}\r\n```"
    ],
    "utterance": "Extract the name from each product object and its corresponding URL, outputting objects with keys name and api.",
    "expressions": [
      ".report.api_http[] | {name: .[0].name, api: .[1]}",
      ".report.api_http[] | {name:values[0][\"name\"],api:values[1]}"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "details": {
              "value": "Details"
            },
            "network": {
              "label": "Network:",
              "value": "test"
            },
            "title": {
              "value": "Test Report"
            },
            "update": {
              "label": "Validation last update:",
              "value": "2020-07-15 17:40 UTC"
            }
          },
          "report": {
            "api_http": [
              [
                {
                  "html_name": "Product 1",
                  "name": "lookproduct1",
                  "rank": 3
                },
                "http://testapi.api.com",
                "GB",
                "TEST"
              ],
              [
                {
                  "html_name": "Product 2",
                  "name": "lookproduct2",
                  "rank": 3
                },
                "http://testapi2.api.com",
                "GB",
                "TEST"
              ],
              [
                {
                  "html_name": "Product 3",
                  "name": "lookproduct3",
                  "rank": 3
                },
                "http://testapi3.api.com",
                "GB",
                "TEST"
              ],
              [
                {
                  "html_name": "Product 4",
                  "name": "lookproduct4",
                  "rank": 3
                },
                "http://testapi.api.com",
                "GB",
                "TEST"
              ]
            ]
          }
        },
        "output": [
          {
            "name": "lookproduct1",
            "api": "http://testapi.api.com"
          },
          {
            "name": "lookproduct2",
            "api": "http://testapi2.api.com"
          },
          {
            "name": "lookproduct3",
            "api": "http://testapi3.api.com"
          },
          {
            "name": "lookproduct4",
            "api": "http://testapi.api.com"
          }
        ]
      }
    ],
    "identifier": 62921945
  },
  {
    "context": [
      "TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns[0])",
      "[Container] 2020/07/17 02:20:27 Running command TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns|.[0])",
      "echo \"Task ID is $TASK_ID\""
    ],
    "utterance": "Extract the first element of the taskArns array from the response to a list-tasks command.",
    "expressions": [
      ".taskArns[0]"
    ],
    "data": [
      {
        "input": {
          "taskArns": [
            "arn:aws:ecs:us-west-2:420785284875:task/f6a58bda-d564-4213-8ac9-bccb82244f16"
          ]
        },
        "output": "arn:aws:ecs:us-west-2:420785284875:task/f6a58bda-d564-4213-8ac9-bccb82244f16"
      }
    ],
    "identifier": 62946697
  },
  {
    "context": [
      "I'd like to add information to the `properties.hardwareProfile` key inside the first element so it becomes:",
      "Your idea was right, but by virtue of using `+` on the object at first index, you lost the objects at other indices. You need to use the append operator `+=`",
      "jq --argjson new '{ \"newProperty\":\"new_value\", \"anotherNewProperty\":\"another_new_value\" }' \\\n    '.[0].properties.hardwareProfile += $new' json",
      "jq --argjson new \"$VM_SIZE_INFO\" '.[0].properties.hardwareProfile += $new' json"
    ],
    "utterance": "Add new properties with specified keys and values to the hardwareProfile object inside the properties of the first array element.",
    "expressions": [
      ".[0].properties.hardwareProfile += { \"newProperty\": \"new_value\", \"anotherNewProperty\": \"another_new_value\" }",
      "jq --argjson new '{ \"newProperty\":\"new_value\", \"anotherNewProperty\":\"another_new_value\" }' '.[0].properties.hardwareProfile += $new'",
      "jq --argjson new \"$VM_SIZE_INFO\" '.[0].properties.hardwareProfile += $new'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "element1",
            "properties": {
              "hardwareProfile": {
                "vmSize": "vm_size"
              }
            }
          },
          {
            "name": "element2",
            "properties": {
              "hardwareProfile": {
                "vmSize": "vm_size"
              }
            }
          }
        ],
        "output": [
          {
            "name": "element1",
            "properties": {
              "hardwareProfile": {
                "vmSize": "vm_size",
                "newProperty": "new_value",
                "anotherNewProperty": "another_new_value"
              }
            }
          },
          {
            "name": "element2",
            "properties": {
              "hardwareProfile": {
                "vmSize": "vm_size"
              }
            }
          }
        ]
      }
    ],
    "identifier": 62941158
  },
  {
    "context": [
      "Starting from a JSON array, I&#39;d like to replace an attribute of each item by the contents of a text file.",
      "We have this initial JSON array:\r\n\r\n```javascript\r\n[ \r\n    { &quot;name&quot;: &quot;step-a&quot;, &quot;message&quot;: &quot;step-a message placeholder&quot; },\r\n    { &quot;name&quot;: &quot;step-b&quot;, &quot;message&quot;: &quot;step-b message placeholder&quot; }\r\n]\r\n```",
      "And two text files matching the `name` attribute values (with an added `.txt`):",
      "The goal is to perform the replacement and end up with this JSON array:\r\n```javascript\r\n[ \r\n    { &quot;name&quot;: &quot;step-a&quot;, &quot;message&quot;: &quot;Step A error logs ...&quot; },\r\n    { &quot;name&quot;: &quot;step-b&quot;, &quot;message&quot;: &quot;Step B error logs ...&quot; }\r\n]\r\n```",
      "You can use `input_filename` to achieve the goal very simply and efficiently.",
      "For example, with the following in program.jq\r\n```\r\n# program.jq\r\n(reduce inputs as $step ( {}; .[input_filename | rtrimstr(&quot;.txt&quot;)] = $step )) as $dict\r\n| $a\r\n| map(. + {message: $dict[.name] })\r\n```",
      "the following invocation would yield the expected result:\r\n```\r\njq -n -f program.jq --argfile a array.json step-*.txt\r\n```",
      "Depending on your requirements, you might like to replace the last line of program.jq as given above by:\r\n\r\n    | map(.message = ($dict[.name] // .message))"
    ],
    "utterance": "Replace the message attribute of each array object with the contents of a text file named after the object's name attribute, removing the '.txt' extension for matching.",
    "expressions": [
      "(reduce inputs as $step ( {}; .[input_filename | rtrimstr(\".txt\")] = $step )) as $dict | $a | map(. + {message: $dict[.name] })",
      "(reduce inputs as $step ( {}; .[input_filename | rtrimstr(\".txt\")] = $step )) as $dict | $a | map(.message = ($dict[.name] // .message))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "step-a",
            "message": "step-a message placeholder"
          },
          {
            "name": "step-b",
            "message": "step-b message placeholder"
          }
        ],
        "output": [
          {
            "name": "step-a",
            "message": "Step A error logs ..."
          },
          {
            "name": "step-b",
            "message": "Step B error logs ..."
          }
        ]
      }
    ],
    "identifier": 62933806
  },
  {
    "context": [
      "There is a recordName and payload key which has my values of interest. Some records are wrapped inside another key input.",
      "What i want to extract is id and var2 from all these records into a new csv file.",
      "Since the `payload` object is nested in multiple levels in each of the object, you can apply [Recursive Descent `..`][1] and ignore if the key is not present",
      "jq -r '..| .payload? // empty | [ .id, .var2 ] | @csv' file",
      "jq -r 'if .input then .input.payload else .payload end | [.id, .var2] | @csv' file > newFile"
    ],
    "utterance": "Extract id and var2 fields from all payload objects, regardless of nesting, and output as CSV rows.",
    "expressions": [
      ".. | .payload? // empty | [ .id, .var2 ] | @csv",
      "if .input then .input.payload else .payload end | [.id, .var2] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "input": {
              "payload": {
                "id": "rec1",
                "var2": "imp_val1",
                "var3": "",
                "var4": "000000"
              },
              "recordName": "typeABC"
            }
          },
          {
            "input": {
              "recordName": "typeBCD",
              "payload": {
                "var5": "val_var66",
                "recordType": "typeA",
                "id": "rec2",
                "var2": "imp_val2",
                "var3": "",
                "var4": "000000"
              }
            }
          },
          {
            "recordName": "typeEFG",
            "payload": {
              "var5": "val_var55",
              "recordType": "typeA",
              "id": "rec3",
              "var2": "imp_val3",
              "var3": "",
              "var4": ""
            }
          },
          {
            "payload": {
              "id": "rec4",
              "var2": "imp_val4",
              "var3": "",
              "var4": "000000"
            },
            "recordName": "typeABC"
          }
        ],
        "output": [
          "\"rec1\",\"imp_val1\"",
          "\"rec2\",\"imp_val2\"",
          "\"rec3\",\"imp_val3\"",
          "\"rec4\",\"imp_val4\""
        ]
      }
    ],
    "identifier": 62948269
  },
  {
    "context": [
      "I\u2019m trying to parse JSON output from the AWS CLI.  What I\u2019m looking for are security group names with specific tags below them.",
      "I\u2019d like each group to have the Service Tag below it so I tried this but it didn\u2019t work.",
      "$ aws ec2 describe-security-groups | jq  -r '.SecurityGroups[].GroupName,.SecurityGroups[].Tags[]|select(.Key == \"Service\")'",
      "jq: error (at <stdin>:225): Cannot index string with string \"Key\""
    ],
    "utterance": "For each security group, output its name together with the value of its tag whose Key is \"Service\".",
    "expressions": [
      ".SecurityGroups[] | {GroupName, Service: (.Tags[]? | select(.Key==\"Service\") | .Value)}"
    ],
    "identifier": 62953962
  },
  {
    "context": [
      "Since I don't know the key (?), I'm able to use this jq command \n\njq '.. | .x? | select(.)'\n\nto locate .x & print its contents , but what do I do if I want to print all contents inside ?? ",
      ". as $in\n| paths as $p \n| $p\n| select($p[-1] == \"x\")\n| $in\n| getpath($p[:-2])[]",
      "Output\n\"y\"\n\"F\"\n\"U\""
    ],
    "utterance": "Return all values from the object that contains a key with value 'x', without knowing the parent object's key name.",
    "expressions": [
      ". as $in | paths as $p | $p | select($p[-1] == \"x\") | $in | getpath($p[:-2])[]"
    ],
    "data": [
      {
        "input": {
          "A": "B",
          "?": {
            "x": "y",
            "D": "F",
            "G": "U"
          }
        },
        "output": [
          "y",
          "F",
          "U"
        ]
      }
    ],
    "identifier": 62961988
  },
  {
    "context": [
      "And the question: in xpath, for example, there are ways to do the reverse: given an element, an xpath function will return the xpath to the element within the document. Is there a way to do that with jq? That is, given \"XML\", is there a way to get .[1].name as the output?",
      "get paths in array form using `path` built-in,",
      "path(recurse | select(.==\"XML\")) | \".[\\(map(tojson) | join(\"][\"))]\"",
      "To get the JSON representation of the path(s) of interest, you could write:",
      "paths as $p | select(getpath($p) == \"XML\") | $p",
      "Producing jq-style path expressions",
      "\".[\" + (map(tojson)|join(\"][\")) + \"]\""
    ],
    "utterance": "Find the path expression to the first value equal to \"XML\" in the data.",
    "expressions": [
      "path(recurse | select(.==\"XML\")) | \".[\\(map(tojson) | join(\"][\"))]\"",
      "paths as $p | select(getpath($p) == \"XML\") | \".[\" + (map(tojson)|join(\"][\")) + \"]\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "JSON",
            "good": true
          },
          {
            "name": "XML",
            "good": false
          }
        ],
        "output": ".[1][\"name\"]"
      }
    ],
    "identifier": 62955547
  },
  {
    "context": [
      "I cannot share curl command as it has sensitive information but updating i value(1)(updated to mimic real value) that I'm having problem with. jq gives parse error",
      "Below are sample i values.",
      "I'm trying to extract fullDisplayName value and I have tried some options like",
      "It also appears that it would be much simpler if you focused on using curl and jq to extract the information, without any grep or tr invocation and without any shell looping.",
      "a single invocation of jq along the following lines should do the job:",
      "jq -c '.allBuilds[] | .fullDisplayName | gsub(\"\u00bb\";\"\")'"
    ],
    "utterance": "Extract the fullDisplayName field from each object in the allBuilds array, removing all '\u00bb' characters from the string.",
    "expressions": [
      ".allBuilds[] | .fullDisplayName | gsub(\"\u00bb\";\"\")"
    ],
    "data": [
      {
        "input": {
          "allBuilds": [
            {
              "_class": "org.jenkinsci.plugins.workflow.job.WorkflowRun",
              "actions": [],
              "fullDisplayName": "Hello \u00bb Java \u00bb World \u00bb master #25",
              "id": "25",
              "number": 25,
              "timestamp": 1575582153372
            },
            {
              "_class": "org.jenkinsci.plugins.workflow.job.WorkflowRun",
              "actions": [],
              "fullDisplayName": "Hello\u00bbJava\u00bbWorld\u00bbmaster#21",
              "id": "21",
              "number": 21,
              "timestamp": 1574705384077
            }
          ]
        },
        "output": [
          "Hello Java World master #25",
          "HelloJavaWorldmaster#21"
        ]
      }
    ],
    "identifier": 62943209
  },
  {
    "context": [
      "And I want to get:\r\n\r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.141,1.1413,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000",
      "Ideally the output shall also pad with zeros, with 1 and 5 being parameters to specify that the first two columns are numbers with 1 natural place and 5 decimal places (although this step can be done easily with `awk`):\r\n\r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.14100,1.14130,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000",
      "jq -r '.ticks[] | [.b, .a, .t] | join(\",\")' test2",
      "You can put together a script, name it `script.jq` and do below. Note that the logic below will _not_ work for numbers in scientific notation.\r\n\r\n    #!/usr/bin/jq -f\r\n    \r\n    def pad($len): \r\n      tostring | \r\n      match(\"^([0-9]*).([0-9]+)$\").captures[1].length as $dec |\r\n      ($len - $dec) as $l  |\r\n      . + (\"0\" * ($l)) [:$l];\r\n    \r\n    .ticks[] | [ (.b|pad(5)), (.a|pad(5)), .t ] | join(\",\")",
      "Here\u2019s an idiomatic jq-only solution to the problem, understood to require that the number of digits to the right of a decimal point, if present, be as specified.  The -r command-line option should be used.\r\n```\r\n# format numbers whose tostring representation has a decimal point\r\n# so that the number of digits to the right of the decimal point is $dd\r\n# assuming $dd >= 0\r\ndef format($dd):\r\n  def rpad: (. + $dd * \"0\") | .[:$dd];\r\n  tostring\r\n  | index(\".\") as $dec\r\n  | if $dec then .[0:$dec+1] + (.[$dec+1:]|rpad)\r\n    else .\r\n    end ;\r\n\r\n.ticks[]\r\n| [(.b | format(1)), (.a | format(5)), .t ]\r\n| join(\",\")"
    ],
    "utterance": "Extract each record's b, a, and t fields as comma-separated values, ensuring b has 1 digit before and 5 after the decimal point, a has 1 digit before and 5 after, and t is unchanged, padding with zeros if necessary.",
    "expressions": [
      ".ticks[] | [.b, .a, .t] | join(\",\")",
      "def pad($len): tostring | match(\"^([0-9]*).([0-9]+)$\").captures[1].length as $dec | ($len - $dec) as $l  | . + (\"0\" * ($l)) [:$l];\n.ticks[] | [ (.b|pad(5)), (.a|pad(5)), .t ] | join(\",\")",
      "def format($dd):\n  def rpad: (. + $dd * \"0\") | .[:$dd];\n  tostring\n  | index(\".\") as $dec\n  | if $dec then .[0:$dec+1] + (.[$dec+1:]|rpad)\n    else .\n    end ;\n\nticks[]\n| [(.b | format(5)), (.a | format(5)), .t ]\n| join(\",\")"
    ],
    "data": [
      {
        "input": {
          "day": "2020-07-15",
          "map": {
            "a": "ask",
            "b": "bid",
            "t": "timestamp"
          },
          "msLatency": 52,
          "pair": "EUR/USD",
          "status": "success",
          "ticks": [
            {
              "b": 1.14105,
              "a": 1.14106,
              "x": 48,
              "t": 1594771200000
            },
            {
              "b": 1.14105,
              "a": 1.14106,
              "x": 48,
              "t": 1594771201000
            },
            {
              "b": 1.14103,
              "a": 1.14104,
              "x": 48,
              "t": 1594771202000
            },
            {
              "b": 1.141,
              "a": 1.1413,
              "x": 48,
              "t": 1594771203000
            },
            {
              "b": 1.14103,
              "a": 1.14104,
              "x": 48,
              "t": 1594771205000
            },
            {
              "b": 1.14094,
              "a": 1.14095,
              "x": 48,
              "t": 1594778803000
            }
          ],
          "type": "forex"
        },
        "output": [
          "1.14105,1.14106,1594771200000",
          "1.14105,1.14106,1594771201000",
          "1.14103,1.14104,1594771202000",
          "1.14100,1.14130,1594771203000",
          "1.14103,1.14104,1594771205000",
          "1.14094,1.14095,1594778803000"
        ]
      }
    ],
    "identifier": 62938833
  },
  {
    "context": [
      "And I want to extract the pair label/unicode from each inner object.",
      ".[] | {unicode,\"label\": .label}",
      "{ \"unicode\":\"f26e\",\"label\":\"pink\" }\n{ \"unicode\":\"b1e3\",\"label\":\"red\" }\n{ \"unicode\":\"11a2\",\"label\":\"blue\" }"
    ],
    "utterance": "Extract the label and unicode properties from each top-level object as pairs.",
    "expressions": [
      ".[] | {unicode,\"label\": .label}"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "unicode": "f26e",
            "label": "pink",
            "free": false
          },
          "key2": {
            "unicode": "b1e3",
            "label": "red",
            "free": true
          },
          "key3": {
            "unicode": "11a2",
            "label": "blue",
            "free": false
          }
        },
        "output": [
          {
            "unicode": "f26e",
            "label": "pink"
          },
          {
            "unicode": "b1e3",
            "label": "red"
          },
          {
            "unicode": "11a2",
            "label": "blue"
          }
        ]
      }
    ],
    "identifier": 62973410
  },
  {
    "context": [
      "i want an expected output like this",
      "    [\n    {\n      \"param1\": \"element1.value1\",\n      \"param2\": \"element1.value2\"\n    },\n    {\n      \"param1\": \"element2.value1\",\n      \"param2\": \"element2.value2\"\n    }\n    ]",
      "If you're dealing with just two properties from an object, just select the objects to put into an array, then put into an array.",
      "[\n  .element1, .element2\n]",
      "In general, you could use this to gather all values of an object. This should keep the objects in document order.",
      "[\n  .[]\n]"
    ],
    "utterance": "Convert all property values of an object into a single array of objects preserving order.",
    "expressions": [
      "[.element1, .element2]",
      "[.[]]"
    ],
    "data": [
      {
        "input": {
          "element1": {
            "param1": "element1.value1",
            "param2": "element1.value2"
          },
          "element2": {
            "param1": "element2.value1",
            "param2": "element2.value2"
          }
        },
        "output": [
          {
            "param1": "element1.value1",
            "param2": "element1.value2"
          },
          {
            "param1": "element2.value1",
            "param2": "element2.value2"
          }
        ]
      }
    ],
    "identifier": 62973375
  },
  {
    "context": [
      "I have a json file that looks like this:\n\n    {\n        \"main_object\": {\n            \"child1\": [\"banana\", \"apple\", \"orange\"]\n        }\n    }\n\nI need to add another child object and rewrite this file, the problem is that this child object needs to be generated dynamically.",
      "With `bash` and `zsh`:\n\n    child_name=\"child2\"\n    fruits='[\"orange\",\"potato\",\"watermelon\"]'\n\n    added_string=$(printf '.main_object += {%s: %s}' \"$child_name\" \"$fruits\")\n    cat file | jq \"$added_string\"  # quotes are important",
      "Output:\n<pre>\n{\n  \"main_object\": {\n    \"child1\": [\n      \"banana\",\n      \"apple\",\n      \"orange\"\n    ],\n    \"child2\": [\n      \"orange\",\n      \"potato\",\n      \"watermelon\"\n    ]\n  }\n}\n</pre>"
    ],
    "utterance": "Add a new field named child2 with value [\"orange\", \"potato\", \"watermelon\"] to main_object.",
    "expressions": [
      ".main_object += {child2: [\"orange\",\"potato\",\"watermelon\"]}"
    ],
    "data": [
      {
        "input": {
          "main_object": {
            "child1": [
              "banana",
              "apple",
              "orange"
            ]
          }
        },
        "output": {
          "main_object": {
            "child1": [
              "banana",
              "apple",
              "orange"
            ],
            "child2": [
              "orange",
              "potato",
              "watermelon"
            ]
          }
        }
      }
    ],
    "identifier": 63004420
  },
  {
    "context": [
      "I want to modify the output to be:\r\n\r\n***SPACEKEY : GROUPNAME : USERID1,USERID2***",
      "SPACEKEY & GROUPNAME are 2 variables whose value changes in every iteration.",
      "jq -r --arg prefix \"SPACEKEY : GROUPNAME : \" '\r\n   $prefix + (.results | map(.username) | join(\",\"))\r\n' GroupList.json",
      "SPACEKEY : GROUPNAME : USERID1,USERID2"
    ],
    "utterance": "Output the usernames as a comma-separated list, prefixed by a given string containing SPACEKEY and GROUPNAME.",
    "expressions": [
      "jq -r --arg prefix \"SPACEKEY : GROUPNAME : \" '$prefix + (.results | map(.username) | join(\",\"))' GroupList.json"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "type": "known",
              "username": "USERID1",
              "displayName": "DISPLAYNAME1",
              "_links": {
                "self": "https://confluence.com/rest/api/user?key=123"
              },
              "_expandable": {
                "status": ""
              }
            },
            {
              "type": "known",
              "username": "USERID2",
              "displayName": "DISPLAYNAME2",
              "_links": {
                "self": "https://confluence.com/rest/api/user?key=1234"
              },
              "_expandable": {
                "status": ""
              }
            }
          ],
          "start": 0,
          "limit": 50000,
          "size": 2,
          "_links": {
            "self": "https://confluence.com/rest/api/group/GROUPNAME/member",
            "base": "https://confluence.com"
          }
        },
        "output": "SPACEKEY : GROUPNAME : USERID1,USERID2"
      }
    ],
    "identifier": 62993611
  },
  {
    "context": [
      "However, when I ran jq on our JSON file, it rounded all of our bigints.",
      "Examples using a recent \"master\" version:\n```\n    jqMaster -n -M '[0000,\n     10000000000000000000000000000000000000012, \n     1.0000000000000000000000000000000000000012, \n     1000000000000000000000000000000000000001210000000000000000000000000000000000000012,\n     0.1e123456]'\n```\n### Output\n```\n[\n  0,\n  10000000000000000000000000000000000000012,\n  1.0000000000000000000000000000000000000012,\n  1000000000000000000000000000000000000001210000000000000000000000000000000000000012,\n  1E+123455\n]\n```",
      "Another option would be to use \u201cgojq\u201d, the Go implementation of jq that uses unbounded-precision representation of integer literals."
    ],
    "utterance": "Output numeric values without rounding, preserving the full precision of large integers such as 10000000000000000000000000000000000000012.",
    "expressions": [
      "[10000000000000000000000000000000000000012, 1.0000000000000000000000000000000000000012, 1000000000000000000000000000000000000001210000000000000000000000000000000000000012, 0.1e123456]"
    ],
    "data": [
      {
        "input": [
          0,
          10000000000000000000000000000000000000012,
          1.0,
          1000000000000000000000000000000000000001210000000000000000000000000000000000000012,
          Infinity
        ],
        "output": [
          0,
          10000000000000000000000000000000000000012,
          1.0,
          1000000000000000000000000000000000000001210000000000000000000000000000000000000012,
          Infinity
        ]
      }
    ],
    "identifier": 63018852
  },
  {
    "context": [
      "I'd like to aggregate a list of objects like this:\r\n\r\n[\r\n  {\"a\": 1, \"b\": 2},\r\n  {\"a\": 3, \"b\": 4}\r\n]\r\n\r\nTo a single object with list values:\r\n\r\n{\r\n  \"a\": [1,3],\r\n  \"b\": [2,4]\r\n}",
      "A straightforward and efficient approach would be:\r\n```\r\nreduce .[] as $o ({};\r\n  reduce ($o|keys_unsorted[]) as $k (.;\r\n    .[$k] += [$o[$k]]))\r\n```",
      "Here is another approach using [reduce](https://stedolan.github.io/jq/manual/#Reduce) and [to_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries):\r\n```\r\nreduce ( .[] | to_entries[] ) as {$key,$value} ({}; .[$key] += [$value]) \r\n```"
    ],
    "utterance": "Aggregate a list of objects so that values for each key are collected into arrays keyed by their names.",
    "expressions": [
      "reduce .[] as $o ({}; reduce ($o|keys_unsorted[]) as $k (.; .[$k] += [$o[$k]]))",
      "reduce ( .[] | to_entries[] ) as {$key,$value} ({}; .[$key] += [$value])"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 3,
            "b": 4
          }
        ],
        "output": {
          "a": [
            1,
            3
          ],
          "b": [
            2,
            4
          ]
        }
      }
    ],
    "identifier": 63023754
  },
  {
    "context": [
      "I am trying to get all the date values in a json array for the dates inside the england-and-wales value.",
      "Im not sure how to only pick dates inside the england-and-wales array?",
      "To get a stream of the dates for just \"england-and-wales\" efficiently:\n\n    .[\"england-and-wales\"] | .events[] | .date",
      "If you wanted these sorted and \"uniquified\", simply delay the itemization (`[]`):\n\n    .[\"england-and-wales\"] | .events | map(.date) | unique[]"
    ],
    "utterance": "Extract all date values from the events belonging to england-and-wales.",
    "expressions": [
      ".[\"england-and-wales\"] | .events[] | .date",
      ".[\"england-and-wales\"] | .events | map(.date) | unique[]"
    ],
    "data": [
      {
        "input": {
          "england-and-wales": {
            "division": "england-and-wales",
            "events": [
              {
                "title": "New Year\u2019s Day",
                "date": "2015-01-01",
                "notes": "",
                "bunting": true
              },
              {
                "title": "Good Friday",
                "date": "2015-04-03",
                "notes": "",
                "bunting": false
              }
            ]
          },
          "scotland": {
            "division": "scotland",
            "events": [
              {
                "title": "New Year\u2019s Day",
                "date": "2015-01-01",
                "notes": "",
                "bunting": true
              },
              {
                "title": "2nd January",
                "date": "2015-01-02",
                "notes": "",
                "bunting": true
              },
              {
                "title": "Good Friday",
                "date": "2015-04-03",
                "notes": "",
                "bunting": false
              },
              {
                "title": "Early May bank holiday",
                "date": "2015-05-04",
                "notes": "",
                "bunting": true
              }
            ]
          }
        },
        "output": [
          "2015-01-01",
          "2015-04-03"
        ]
      }
    ],
    "identifier": 63033862
  },
  {
    "context": [
      "I have a json file and I have to extract only the value of the key \"data\" and decode the base64-encoded.",
      "I tried using jq\n\n     jq -r '.[].data' < test.json | base64 --decode\nBut I got this error:\n\n    jq: error (at <stdin>:3): Cannot index string with string \"data\"",
      "If the string in .data were a valid base64 encoding of a UTF-8 string, the following would be equivalent:\n\n    jq -r .data input.json | base64 -D\n\nand\n\n    jq -r '.data|@base64d' input.json"
    ],
    "utterance": "Extract the value of the key \"data\" and decode its base64-encoded content.",
    "expressions": [
      "jq -r .data input.json | base64 -D",
      "jq -r '.data|@base64d' input.json"
    ],
    "data": [
      {
        "input": {
          "equno": "229151246954324320",
          "data": "CdwL703m6njjyJ7tdEXdRoYKKv49oatv9UWvdLONpWgd407fakXNfbt18j+qKb/toYgHZvj34ig7iu4XN7BfrqTf/wNsIdVNJ67cH9hCyIfULWLgyT01vQ7u5zS5vSB9hazXTQHRYGxpV+eCrVFMEdxHId54sJDn+KL8hea93WyQKlFwMDO0QQD5X2lK02Y88uI7MehBUFXzK5jNTgKmLtUE9KoM4xF6bEzm2oNMrxz0QwOB4b/tvRvhThb/r+Wgb32gV3UBZBZ/RP4ID+lc7JE7TLVRyeGCNA+uV11/no358XZdGo/E5Aq7KZ95W+rQ8TE3/PLbodAhWZ+1wAcXvfuxJxpIm0giOZv3Dys/pZesM5wbdwaNrFnD+ngHfXB67IxiBM3oRRxC7CBHoFvQFjC8g2E3dk1ELP6VPex24lPJY1JeBwuy8DQroN7rxa4bwLAE6Z3SyL16dpwYdMmAB2YN2h4nMGfl1TMXPGsJKxcSv4tBLj905WTGYgDKG3sQ0AR4YHoPKni7/rUZQb/hM25wXFKYNRzGU6EIleCTP4fl1vqASLFUHDS0GqjwcYkCOilvDbb3PqNqDzPEI84L7XDidiWQ8XKfzw7ryjuIaw1b1ODqN3+ctnny88WXTzANzwA5wjqfhDJDGpHr58fQgi1/j2QIsFBt+VoOslxvx1YQvbubDTwM7dTEwWDY0U5+l8KvSv9fYIMbNYxjwXU3tR2SFhClumNjisUE0lHgCBAfkbTA5Fw9eW3+QRZdB5rY/7DWgxlRnBORZ54c5xxTnsk2ntFm14zQA8HN7zv09FQW+sMk6B767cyzi5HoEkf+PjnNh78OrIPVOFtigMYUb5PdDWDzjDCu2+9dN4mm5aml+/SIOFDUHg6aX+GLj7c0tI0thMFAR6dKP6QtmVbUanF7gSt+L2c4qRq48s3QYMlrTr++PqeoCYNuhWIo2iXllvzERarLDU/pxZNfGB39bFmjmiAnLwmDqNZuVTi40/A38AI+r4f39Y/eywskz/rco1CZGUXxd0FJj0pwdO9H0eedwVgXAmi3KYy3j5MZBWeObqs/ufvRpHjDeh54Bq91DrxcKPya/b6FGDxH73jIgB9Y9x/mbZq2h20H9fbbV+hTk8XIA5ItY+2N9J7FHiJ+NyQbl4UNZT/GVF4HS+NXplgzEAEIlzgRwrNoY0GJzeocxZlAa5f5ANu7OHltqpSTAZ0PzVCopG1NgwaQEpS08mVAtgXo7jq34VejdNuHiTo+/ht3Dn+C+WzKXHZIABkhHjGg1Bv4hJHuLXIpQjIE0xwQo2UcTmcAYvrGO6FcHZz+eRUmJyrtsJczwZK7nimfgJ6T/iuggPVwyn9pifU9VA=="
        }
      }
    ],
    "identifier": 62928437
  },
  {
    "context": [
      "I need to produce a table like this",
      "| NetworkAclId            | RuleNumber    | Egress    | Protocol  | PortRange.From    | PortRange.To  | CidrBlock | RuleAction  |",
      "|-------------------------|---------------|-----------|-----------|-------------------|---------------|-----------|-------------|",
      "| acl-09811190de1965cd4   | 100           | true      | 6         | 80                | 80            | 0.0.0.0/0 | allow       |",
      "| acl-09811190de1965cd4   | 200           | true      | 6         | 443               | 443           | 0.0.0.0/0 | allow       |",
      "| acl-0f1c265110106d23d   | 100           | false     | 6         | 80                | 80            | 0.0.0.0/0 | deny        |",
      "| acl-0f1c265110106d23d   | 200           | true      | 7         | 443               | 443           | 0.0.0.0/0 | deny        |",
      "The Entries.* should only correspond to the NetworkAclId of its parent.",
      "jq -r '\n    .NetworkAcls[] | range(.Associations | length) as $i | [\n        .Associations[$i].NetworkAclId,\n        (.Entries[$i] |\n            .RuleNumber,\n            .Egress,\n            .Protocol,\n            .PortRange.From,\n            .PortRange.To,\n            .CidrBlock,\n            .RuleAction\n        )\n    ] | @csv\n' file.json",
      "\"acl-09811190de1965cd4\",100,true,\"6\",80,80,\"0.0.0.0/0\",\"allow\"",
      "\"acl-09811190de1965cd4\",200,true,\"6\",443,443,\"0.0.0.0/0\",\"allow\"",
      "\"acl-0f1c265110106d23d\",100,false,\"6\",80,80,\"0.0.0.0/0\",\"deny\"",
      "\"acl-0f1c265110106d23d\",200,true,\"7\",443,443,\"0.0.0.0/0\",\"deny\""
    ],
    "utterance": "Output a table with columns NetworkAclId, RuleNumber, Egress, Protocol, PortRange.From, PortRange.To, CidrBlock, and RuleAction where each row corresponds to an entry for its parent NetworkAclId.",
    "expressions": [
      ".NetworkAcls[] | .Entries[] | [ .NetworkAclId, .RuleNumber, .Egress, .Protocol, .PortRange.From, .PortRange.To, .CidrBlock, .RuleAction ]",
      ".NetworkAcls[] | [ .NetworkAclId as $id | .Entries[] | [ $id, .RuleNumber, .Egress, .Protocol, .PortRange.From, .PortRange.To, .CidrBlock, .RuleAction ] ] | .[]",
      ".NetworkAcls[] | .Entries[] | \"\u007f(.NetworkAclId) \u007f(.RuleNumber) \u007f(.Egress) \u007f(.Protocol) \u007f(.PortRange.From) \u007f(.PortRange.To) \u007f(.CidrBlock) \u007f(.RuleAction)\"",
      ".NetworkAcls[] | .Entries[] | {NetworkAclId: .NetworkAclId, RuleNumber, Egress, Protocol, PortRangeFrom: .PortRange.From, PortRangeTo: .PortRange.To, CidrBlock, RuleAction}",
      ".NetworkAcls[] | .Entries[] | {NetworkAclId: .NetworkAclId, RuleNumber: .RuleNumber, Egress: .Egress, Protocol: .Protocol, PortRange: {From: .PortRange.From, To: .PortRange.To}, CidrBlock: .CidrBlock, RuleAction: .RuleAction}"
    ],
    "data": [
      {
        "input": {
          "NetworkAcls": [
            {
              "Associations": [
                {
                  "NetworkAclAssociationId": "aclassoc-0360bceb2b4788870",
                  "NetworkAclId": "acl-09811190de1965cd4",
                  "SubnetId": "subnet-9fa0aac4"
                },
                {
                  "NetworkAclAssociationId": "aclassoc-08ceb0c1375cb9729",
                  "NetworkAclId": "acl-09811190de1965cd4",
                  "SubnetId": "subnet-db2de5bd"
                }
              ],
              "Entries": [
                {
                  "CidrBlock": "0.0.0.0/0",
                  "Egress": true,
                  "PortRange": {
                    "From": 80,
                    "To": 80
                  },
                  "Protocol": "6",
                  "RuleAction": "allow",
                  "RuleNumber": 100
                },
                {
                  "CidrBlock": "0.0.0.0/0",
                  "Egress": true,
                  "PortRange": {
                    "From": 443,
                    "To": 443
                  },
                  "Protocol": "6",
                  "RuleAction": "allow",
                  "RuleNumber": 200
                }
              ],
              "IsDefault": false,
              "NetworkAclId": "acl-09811190de1965cd4",
              "VpcId": "vpc-12345678",
              "OwnerId": "1234567890"
            },
            {
              "Associations": [
                {
                  "NetworkAclAssociationId": "aclassoc-0531b6837ee6948dc",
                  "NetworkAclId": "acl-0f1c265110106d23d",
                  "SubnetId": "subnet-7f23eb19"
                },
                {
                  "NetworkAclAssociationId": "aclassoc-01314abbaca73ae21",
                  "NetworkAclId": "acl-0f1c265110106d23d",
                  "SubnetId": "subnet-44bdb71f"
                }
              ],
              "Entries": [
                {
                  "CidrBlock": "0.0.0.0/0",
                  "Egress": false,
                  "PortRange": {
                    "From": 80,
                    "To": 80
                  },
                  "Protocol": "6",
                  "RuleAction": "deny",
                  "RuleNumber": 100
                },
                {
                  "CidrBlock": "0.0.0.0/0",
                  "Egress": true,
                  "PortRange": {
                    "From": 443,
                    "To": 443
                  },
                  "Protocol": "7",
                  "RuleAction": "deny",
                  "RuleNumber": 200
                }
              ],
              "IsDefault": false,
              "NetworkAclId": "acl-0f1c265110106d23d",
              "VpcId": "vpc-12345678",
              "OwnerId": "1234567890"
            }
          ]
        },
        "output": [
          [
            "acl-09811190de1965cd4",
            100,
            true,
            "6",
            80,
            80,
            "0.0.0.0/0",
            "allow"
          ],
          [
            "acl-09811190de1965cd4",
            200,
            true,
            "6",
            443,
            443,
            "0.0.0.0/0",
            "allow"
          ],
          [
            "acl-0f1c265110106d23d",
            100,
            false,
            "6",
            80,
            80,
            "0.0.0.0/0",
            "deny"
          ],
          [
            "acl-0f1c265110106d23d",
            200,
            true,
            "7",
            443,
            443,
            "0.0.0.0/0",
            "deny"
          ]
        ]
      }
    ],
    "identifier": 62818307
  },
  {
    "context": [
      "Trying to convert a JSON array into a CSV file using `jq` but not able to succeed.",
      "Following is my JSON output from `curl` command:",
      "How should i modify the `jq` command to convert JSON to CSV ?",
      "If you just want the `results` array of objects:",
      "jq -r '([\"id\",\"ph_no\",\"status\"], (.results[] | [.id, .ph_no, .status])) | @csv' temp.json"
    ],
    "utterance": "Extract all objects in the results array, selecting the fields id, ph_no, and status, and convert them into a CSV with a header row.",
    "expressions": [
      "([\"id\",\"ph_no\",\"status\"], (.results[] | [.id, .ph_no, .status])) | @csv"
    ],
    "data": [
      {
        "input": {
          "requestID": "463aeb25-f4c3-40ba-a031-e62d698afc6e",
          "signature": {
            "id": "json",
            "ph_no": "json",
            "status": "json"
          },
          "results": [
            {
              "id": "9f34-66758813073c",
              "ph_no": "343434325",
              "status": "active"
            },
            {
              "id": "b1a2-30a14a68c576",
              "ph_no": "6767666764",
              "status": "active"
            },
            {
              "id": "9af4-5b231f05ce37",
              "ph_no": "546745435",
              "status": "active"
            },
            {
              "id": "99bd-ed67fd139074",
              "ph_no": "323246566",
              "status": "active"
            },
            {
              "id": "9ecc-8277c3ffa274",
              "ph_no": "6753643554",
              "status": "active"
            }
          ],
          "status": "success",
          "metrics": {
            "elapsedTime": "29.461027ms",
            "executionTime": "29.364961ms",
            "resultCount": 146,
            "resultSize": 13856
          }
        },
        "output": [
          "\"id\",\"ph_no\",\"status\"",
          "\"9f34-66758813073c\",\"343434325\",\"active\"",
          "\"b1a2-30a14a68c576\",\"6767666764\",\"active\"",
          "\"9af4-5b231f05ce37\",\"546745435\",\"active\"",
          "\"99bd-ed67fd139074\",\"323246566\",\"active\"",
          "\"9ecc-8277c3ffa274\",\"6753643554\",\"active\""
        ]
      }
    ],
    "identifier": 63052020
  },
  {
    "context": [
      "Rather than using bash constructs to iterate through the JSON array, it would almost certainly be better to use jq's support for iteration and selection. For example:",
      "jq '.[] | select(.eventId == 22)' <<< ${commandGetEvents}",
      "So if you just want the startedEventId value (or values) corresponding to .eventId == 22, you could write:",
      "jq '.[] | select(.eventId == 22) | .startedEventId' <<< ${commandGetEvents}"
    ],
    "utterance": "Find the startedEventId value for the object whose eventId is 22.",
    "expressions": [
      ".[] | select(.eventId == 22) | .startedEventId"
    ],
    "data": [
      {
        "input": [
          {
            "eventId": 22,
            "Name": "Bob",
            "Activity": "Eat Food",
            "startedEventId": 15
          },
          {
            "eventId": 21,
            "Name": "Smith",
            "Activity": "Ride a bike",
            "startedEventId": 13
          },
          {
            "eventId": 20,
            "Name": "Tony",
            "Activity": "Print paper",
            "startedEventId": 10
          }
        ],
        "output": 15
      }
    ],
    "identifier": 63059832
  },
  {
    "context": [
      "I am trying to merge all json files in a directory (can be many).",
      "jq -s \"reduce .[] as $obj ({}; . * $obj)\" *.json",
      "jq -s add *.json",
      "jq -s '.' *.json",
      "To merge two json files using `jq` use this command:\n\n    jq -s \".[0] * .[1]\" file1.json file2.json",
      "Now to merge three json files:\n\n    jq -s \".[0] * .[1] * .[2]\" file1.json file2.json file3.json",
      "Let's follow the same logic and generalise for n files using wildcards.",
      "jq -s '.' *.json > merged.json",
      "jq -s add *.json > merged.json"
    ],
    "utterance": "Merge all files matching *.json in a directory into a single object by recursively combining keys and values.",
    "expressions": [
      "jq -s 'reduce .[] as $obj ({}; . * $obj)' *.json",
      "jq -s \".[0] * .[1] * .[2]\" file1.json file2.json file3.json",
      "s=\"*.json\"; jq -s \"`x=-1; n=$(ls $s | wc -l); while [ $((x++)) -lt $(($n-2)) ]; do printf \\\".[$x] * \\\" ; done; printf \\\".[[\\$((n-1))]]\\\";`\" $s"
    ],
    "data": [
      {
        "input": [
          {
            "days": {
              "2020-05-18": {
                "seconds": 60
              },
              "2020-05-19": {
                "seconds": 30
              },
              "2020-05-20": {
                "seconds": 1400
              }
            },
            "total": {
              "seconds": 1490
            }
          },
          {
            "days": {
              "2020-05-20": {
                "seconds": 95
              },
              "2020-05-21": {
                "seconds": 80
              },
              "2020-05-22": {
                "seconds": 120
              }
            },
            "total": {
              "seconds": 295
            }
          }
        ],
        "output": {
          "days": {
            "2020-05-18": {
              "seconds": 60
            },
            "2020-05-19": {
              "seconds": 30
            },
            "2020-05-20": {
              "seconds": 95
            },
            "2020-05-21": {
              "seconds": 80
            },
            "2020-05-22": {
              "seconds": 120
            }
          },
          "total": {
            "seconds": 295
          }
        }
      }
    ],
    "identifier": 63046989
  },
  {
    "context": [
      "Suppose I have a JSONL file: \r\n\r\n```\r\n# foo.jsonl\r\n\r\n{ \"arbitrary.key\":\"foo\" }\r\n{ \"arbitrary.key\":\"foobar\" }\r\n{ \"arbitrary.key\":\"bar\" }\r\n```",
      "And I would like to filter the rows of this file: \r\n\r\n```\r\n# in pseudo code\r\ncat foo.jsonl | jq '. | where(.\"arbitrary.key\" | is_match(\"^foo\"))'\r\n```",
      "cat foo.jsonl | jq '. | select( .\"arbitrary.key\" | match(\"^f\"))'"
    ],
    "utterance": "Filter each line where the value of 'arbitrary.key' starts with 'foo'",
    "expressions": [
      ". | select( .\"arbitrary.key\" | test(\"^foo\") )",
      ". | select( .\"arbitrary.key\" | match(\"^foo\") )"
    ],
    "data": [
      {
        "input": [
          {
            "arbitrary.key": "foo"
          },
          {
            "arbitrary.key": "foobar"
          },
          {
            "arbitrary.key": "bar"
          }
        ],
        "output": [
          {
            "arbitrary.key": "foo"
          },
          {
            "arbitrary.key": "foobar"
          }
        ]
      }
    ],
    "identifier": 63076675
  },
  {
    "context": [
      "The script works correctly for top level keys such as \"key1\". But it does not work correctly (returns null) for \"key2.key3\".",
      "Using `--arg` prevents your data from being incorrectly parsed as syntax. Usually, a shell variable you're passing into `jq` contains literal data, so this is the correct thing.",
      "In this case, your variable contains syntax, not literal data: The `.` isn't part of the string you want to do a lookup by, but is instead an instruction to jq to do two separate lookups one after the other.",
      "So, in this case, you should do the more obvious thing, *instead of* using `--arg`:",
      "jq -e \".$KEY\""
    ],
    "utterance": "Lookup a key or nested key using a shell variable containing the path, such as 'key2.key3', via indirect expansion in the filter.",
    "expressions": [
      "jq -e \".$KEY\""
    ],
    "data": [
      {
        "input": {
          "key1": "val1",
          "key2": {
            "key3": "val3"
          }
        },
        "output": "val3"
      }
    ],
    "identifier": 63082535
  },
  {
    "context": [
      "the response I get is \n{\"next\":\"/gibberish\"}\n",
      "So I perform another request:\n\ncurl -H \"Accept: application/json\" 'http://example.com/gibberish'\n\nthe response I get is \n{\"next\":\"/anotherGibberish\"}\n",
      "I want to be able to do the curl request, get the `next` information and loop in to the next request.",
      "Any help using jq would also be great.",
      "while resp=$(curl -sS \"http://example.com$next\"); do\n  if ! next=$(jq -er '.next' <<< \"$resp\"); then\n    # `resp' is the final response here\n    # , do whatever you want with it\n    break\n  fi\ndone"
    ],
    "utterance": "Extract the value of the key 'next' from the response, and repeat this until the key no longer exists.",
    "expressions": [
      ".next",
      "jq -er '.next'"
    ],
    "data": [
      {
        "input": {
          "next": "/gibberish"
        },
        "output": "/gibberish"
      },
      {
        "input": {
          "unauthorized": "Authenticate with username and password"
        },
        "output": null
      }
    ],
    "identifier": 63091111
  },
  {
    "context": [
      "The main task is to leave only specified attributes in the tree. The number of levels in the tree may be different.",
      "Is it possible to get the output like the following (leave only clazz, code, children)?",
      "The following recursive function seems to meet the requirements, or at least the filter `.metaModel | transform` transforms the sample input in accordance with the sample output:",
      "def transform:\n  if type == \"object\" and has(\"clazz\")\n  then  {clazz, code} + (if has(\"children\") then {children: (.children|transform)} else null end)\n  elif type == \"array\" then map(transform)\n  else .\n  end;",
      "reduce (tostream|select(.[0][-1]|.==\"clazz\" or .==\"code\" or .==\"children\")) as [$p,$v] (\n  {}; setpath($p;$v)\n)",
      ".metaModel\n| walk( if type == \"object\" and has(\"clazz\")\n        then {clazz, code} + (if .children then { children } else null end )\n        else .\n        end )"
    ],
    "utterance": "Recursively keep only the attributes 'clazz', 'code', and 'children' at every level of a nested structure, with possibly varying depth.",
    "expressions": [
      "def transform: if type == \"object\" and has(\"clazz\") then {clazz, code} + (if has(\"children\") then {children: (.children|transform)} else null end) elif type == \"array\" then map(transform) else . end; .metaModel | transform",
      "reduce (tostream|select(.[0][-1]|.==\"clazz\" or .==\"code\" or .==\"children\")) as [$p,$v] ({}; setpath($p;$v))",
      ".metaModel | walk( if type == \"object\" and has(\"clazz\") then {clazz, code} + (if .children then { children } else null end ) else . end )"
    ],
    "data": [
      {
        "input": {
          "metaModel": [
            {
              "clazz": "AttributeClass1",
              "code": "code1",
              "default": "value1",
              "children": [
                {
                  "clazz": "AttributeClass2",
                  "code": "code21",
                  "default": "value21"
                },
                {
                  "clazz": "AttributeClass1",
                  "code": "code22",
                  "default": "value22",
                  "children": [
                    {
                      "clazz": "AttributeClass1",
                      "code": "code31",
                      "default": "value31",
                      "children": []
                    }
                  ]
                }
              ]
            },
            {
              "clazz": "AttributeClass2",
              "code": "code2",
              "default": "value2"
            }
          ]
        },
        "output": [
          {
            "clazz": "AttributeClass1",
            "code": "code1",
            "children": [
              {
                "clazz": "AttributeClass2",
                "code": "code21"
              },
              {
                "clazz": "AttributeClass1",
                "code": "code22",
                "children": [
                  {
                    "clazz": "AttributeClass1",
                    "code": "code31",
                    "children": []
                  }
                ]
              }
            ]
          },
          {
            "clazz": "AttributeClass2",
            "code": "code2"
          }
        ]
      }
    ],
    "identifier": 63027032
  },
  {
    "context": [
      "I want to find out if id \"13\" is in the json file.",
      "Here is one possibility:\n\n    any(.[]; .id == \"13\")",
      "[[ $(jq < file.json 'any(.id == \"13\")') == \"true\" ]]"
    ],
    "utterance": "Determine if any object in the array has id equal to \"13\".",
    "expressions": [
      "any(.[]; .id == \"13\")",
      "any(.id == \"13\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "45"
          },
          {
            "id": "56"
          },
          {
            "id": "13"
          },
          {
            "id": "5"
          }
        ],
        "output": true
      }
    ],
    "identifier": 63097905
  },
  {
    "context": [
      "I have a JSON `test.json` as follows:",
      "And I would want to join the field `b` of each entry and handle the case of its emptiness:",
      "The following command works...",
      "cat test.json | \n      jq '.[] | .b as $t | if $t then {a: .a, b: $t | join(\", \")} else {a: .a, b: $t} end'",
      "... but it's too long as I have to write almost the same constructor two times.",
      "Depending on how you want to handle `null`/`empty` values you could try these:",
      "map(.b |= (. // [] | join(\", \")))",
      "map(if .b then .b |= join(\", \") else . end)"
    ],
    "utterance": "For each object, join the values in field b with ', '; if b does not exist or is empty, set b to null.",
    "expressions": [
      "map(.b |= (. // [] | join(\", \")))",
      "map(if .b then .b |= join(\", \") else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "a",
            "b": [
              "a",
              "b",
              "c"
            ]
          },
          {
            "a": "a"
          }
        ],
        "output": [
          {
            "a": "a",
            "b": "a, b, c"
          },
          {
            "a": "a",
            "b": null
          }
        ]
      }
    ],
    "identifier": 63093336
  },
  {
    "context": [
      "I have a file with this kind of text with pattern\n\n    [{\"foo\":\"bar:baz:foo*\",\"bar*\":\"baz*\",\"etc\":\"etc\"},\n    {\"foo2\":\"bar2:baz2:foo2*\",\"bar2*\":\"baz2*\",\"etc\":\"etc\"},\n    {\"foo3\":\"bar3:baz3:foo3*\",\"bar3*\":\"baz3*\",\"etc\":\"etc\"},\n    {\"foo4\":\"bar4:baz4:foo4*\",\"bar4*\":\"baz4*\",\"etc\":\"etc\"}]\n\nI  need to take every string like this\n```{\"foo\":\"bar:baz:foo*\",\"bar*\":\"baz*\",\"etc\":\"etc\"}``` and send each of them to some url via curl",
      "Use `jq` command. This is just example parsing.\n\n```\nfor k in $(jq -c '.[]' a.txt); do\n    echo \"hello-\" $k\ndone\n```",
      "You can use the `$k` anywhere inside the loop you want.\n\n```\nfor k in $(jq -c '.[]' a.txt); do\n    curl -d \"$k\" <url>\ndone\n```",
      "I suggest that you can use `jq` to process your json file....\n\n    jq -r '.[] | \"curl -d '\\'' \\(.) '\\''  http://restful.com/api \" ' jsonfile\n",
      "The `-r` tells jq to output the results in raw format (that is, please don't escape quotes and stuff).\nThe script looks like this:\n\n    .[] | \"some string \\(.)\" \n\nThe first `.` means take the whole json structure and the `[]` means iterate through each array element in the structure.",
      "We are using jq to find each element in the json array and insert it into a string.  Our string is this:\n\n    curl -d '<the json dictionary array element>' http://restful.com/api\n",
      "Here's the solution:\n\n    $ jq -r  $'.[] |    \"(.)\"  | gsub( \"\\'\" ; \"\\\\\\\\\\'\" )  | \"echo $\\'\\(.)\\'\" ' jsonfile     | bash\n    {\"foo\":\"bar'baz:foo*\",\"bar*\":\"baz*\",\"etc\":\"etc\"}\n    {\"foo2\":\"bar2:baz2:foo2*\",\"bar2*\":\"baz2*\",\"etc\":\"etc\"}\n    {\"foo3\":\"bar3:baz3:foo3*\",\"bar3*\":\"baz3*\",\"etc\":\"etc\"}\n    {\"foo4\":\"bar4:baz4:foo4*\",\"bar4*\":\"baz4*\",\"etc\":\"etc\"}\n",
      "So we wind up with this when we put the curl back in:\n\n    jq -r  $'.[] |    \"(.)\"  | gsub( \"\\'\" ; \"\\\\\\\\\\'\" )  | \"curl -d $\\'\\(.)\\' http://restful.com/api \" ' jsonfile     | bash\n"
    ],
    "utterance": "Extract each object from an array in a file and output each as a compact string, suitable for use as curl -d data, even when object values may contain single quotes.",
    "expressions": [
      ".[]",
      "-c '.[]'",
      "-r '.[] | \"curl -d '\\'' \\(.) '\\''  http://restful.com/api \" '",
      "$'.[] | \"(.)\"  | gsub( \"\\'\" ; \"\\\\\\\\\\'\" )  | \"curl -d $\\'\\(.)\\' http://restful.com/api \" '"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar:baz:foo*",
            "bar*": "baz*",
            "etc": "etc"
          },
          {
            "foo2": "bar2:baz2:foo2*",
            "bar2*": "baz2*",
            "etc": "etc"
          },
          {
            "foo3": "bar3:baz3:foo3*",
            "bar3*": "baz3*",
            "etc": "etc"
          },
          {
            "foo4": "bar4:baz4:foo4*",
            "bar4*": "baz4*",
            "etc": "etc"
          }
        ],
        "output": [
          "{\"foo\":\"bar:baz:foo*\",\"bar*\":\"baz*\",\"etc\":\"etc\"}",
          "{\"foo2\":\"bar2:baz2:foo2*\",\"bar2*\":\"baz2*\",\"etc\":\"etc\"}",
          "{\"foo3\":\"bar3:baz3:foo3*\",\"bar3*\":\"baz3*\",\"etc\":\"etc\"}",
          "{\"foo4\":\"bar4:baz4:foo4*\",\"bar4*\":\"baz4*\",\"etc\":\"etc\"}"
        ]
      }
    ],
    "identifier": 62963768
  },
  {
    "context": [
      "I want to remove all elements that have a \"tag\" with value \"internal\".",
      "Once found, deleting them can be done using the `del` built-in.",
      "del(.[] | first(select(recurse\n  | objects\n  | has(\"tags\") and (.tags\n    | . == \"internal\" or (\n      type == \"array\" and index(\"internal\")\n    )\n  )\n)))",
      "def hasTag($value):\n  any(.. | select(type==\"object\") | .tags;\n      . == $value or (type == \"array\" and index($value)));",
      "with_entries( select( .value | hasTag(\"internal\") | not) )",
      "walk(if type == \"object\" and has(\"tags\") and (.tags  | . == \"internal\" or (type == \"array\" and index(\"internal\"))) then del(.) else . end) | delpaths([paths as $path | select(getpath($path) == null) | $path])",
      "This will remove all elements that contain 'internal' as 'tag'."
    ],
    "utterance": "Remove all elements, at any level, that have a tags key containing the value internal, whether tags is a string or array.",
    "expressions": [
      "del(.[] | first(select(recurse\n  | objects\n  | has(\"tags\") and (.tags\n    | . == \"internal\" or (\n      type == \"array\" and index(\"internal\")\n    )\n  )\n)))",
      "def hasTag($value): any(.. | select(type==\"object\") | .tags; . == $value or (type == \"array\" and index($value))); with_entries( select( .value | hasTag(\"internal\") | not) )",
      "walk(if type == \"object\" and has(\"tags\") and (.tags  | . == \"internal\" or (type == \"array\" and index(\"internal\"))) then del(.) else . end) | delpaths([paths as $path | select(getpath($path) == null) | $path])"
    ],
    "data": [
      {
        "input": {
          "element1": "Test Element 1",
          "element2": {
            "tags": "internal",
            "data": {
              "data1": "Test Data 1",
              "data2": "Test Data 2"
            }
          },
          "element3": {
            "function1": {
              "tags": [
                "new",
                "internal"
              ]
            },
            "data3": "Test Data 3",
            "data4": "Test Data 4"
          },
          "element4": {
            "function2": {
              "tags": "new"
            },
            "data5": "Test Data 5"
          },
          "structure1": {
            "substructure1": {
              "element5": "Test Element 5",
              "element6": {
                "tags": "internal",
                "data6": "Test Data 6"
              }
            }
          }
        },
        "output": {
          "element1": "Test Element 1",
          "element4": {
            "function2": {
              "tags": "new"
            },
            "data5": "Test Data 5"
          },
          "structure1": {
            "substructure1": {
              "element5": "Test Element 5"
            }
          }
        }
      }
    ],
    "identifier": 63097014
  },
  {
    "context": [
      "I need to sort this json by the key value (as this is the easiest way - earlier I had tried sorting by analysisDate) and get the value of qualityGateStatus for that key.",
      "If, as indicated in the comments, the actual goal is essentially to find the maximum value by .key, then it would be better to use `max_by` rather than `sort_by`.  Based on the comments, the following would suffice:",
      ".pullRequests | max_by(.key).status.qualityGateStatus"
    ],
    "utterance": "Find the qualityGateStatus value for the pull request with the highest key.",
    "expressions": [
      ".pullRequests | max_by(.key).status.qualityGateStatus"
    ],
    "data": [
      {
        "input": {
          "pullRequests": [
            {
              "key": "11346",
              "title": "feature/XXX-Validation",
              "branch": "feature/XXX-Validation",
              "base": "develop",
              "status": {
                "qualityGateStatus": "OK",
                "bugs": 0,
                "vulnerabilities": 0,
                "codeSmells": 1
              },
              "analysisDate": "2020-07-27T14:22:36+0000",
              "url": "https://abc/org/_git/repo/pullrequest/11346",
              "target": "develop"
            },
            {
              "key": "11151",
              "title": "feature/xxx-data",
              "branch": "feature/xxx-data",
              "base": "develop",
              "status": {
                "qualityGateStatus": "OK",
                "bugs": 0,
                "vulnerabilities": 0,
                "codeSmells": 0
              },
              "analysisDate": "2020-07-22T11:11:11+0000",
              "url": "https://abc/org/_git/repo/pullrequest/11151",
              "target": "develop"
            }
          ]
        },
        "output": "OK"
      }
    ],
    "identifier": 63126834
  },
  {
    "context": [
      "Desired Output in one file **output.txt**\r\n\r\n```1000 & Female,Male & 38,26 & adult,adult``` <br/> ```2000 & Male,Male & 63,11 & adult,child```",
      "It's doable in `jq` with some string interpolation:\r\n\r\n```\r\n$ find . -name \"*.json\" -exec jq -r \\\r\n  '(input_filename | gsub(\"^\\\\./|\\\\.json$\";\"\")) as $fname |\r\n   (map(.gender.value) | unique | join(\",\")) as $genders |\r\n   (map(.age|floor|tostring) | join(\",\")) as $ages |\r\n   (map(.age_group) | unique | join(\",\")) as $age_groups |\r\n   \"\\($fname) & \\($genders) & \\($ages) & \\($age_groups)\"' '{}' +\r\n1000 & Female,Male & 38,26 & adult\r\n2000 & Male & 63,11 & adult,child\r\n```"
    ],
    "utterance": "Produce, for each file, a line with the filename (without .json), unique gender values joined by comma, floored ages joined by comma, and unique age_groups joined by comma, all separated by ' & '.",
    "expressions": [
      "(input_filename | gsub(\"^\\./|\\.json$\";\"\")) as $fname | (map(.gender.value) | unique | join(\",\")) as $genders | (map(.age|floor|tostring) | join(\",\")) as $ages | (map(.age_group) | unique | join(\",\")) as $age_groups | \"\u0000($fname) & \u0000($genders) & \u0000($ages) & \u0000($age_groups)\""
    ],
    "data": [
      {
        "input": [
          {
            "gender": {
              "value": "Female"
            },
            "age": 38.58685,
            "age_group": "adult"
          },
          {
            "gender": {
              "value": "Male"
            },
            "age": 26.64953,
            "age_group": "adult"
          }
        ],
        "output": "1000 & Female,Male & 38,26 & adult"
      },
      {
        "input": [
          {
            "gender": {
              "value": "Male"
            },
            "age": 63.8272,
            "age_group": "adult"
          },
          {
            "gender": {
              "value": "Male"
            },
            "age": 11.8287,
            "age_group": "child"
          }
        ],
        "output": "2000 & Male & 63,11 & adult,child"
      }
    ],
    "identifier": 63105247
  },
  {
    "context": [
      "I am trying to execute a simple jq command in windows but it is not working as expected",
      "aws ec2 describe-instances --instance-ids $instanceId --query \"Reservations[0].Instances[0].Tags\" | jq '.[] | select (.Key==\"Name\")'",
      "jq: error: Name/0 is not defined at <top-level>, line 1:\n.[] | select (.Key==Name)\njq: 1 compile error",
      "In Powershell, you have to backslash the double quotes for jq:",
      "'[{\"name\":\"joe\"}]' | jq '.[] | select (.name==\\\"joe\\\")'"
    ],
    "utterance": "Select objects from an array where the 'Key' field is exactly 'Name'.",
    "expressions": [
      ".[] | select (.Key==\\\"Name\\\")"
    ],
    "identifier": 63135630
  },
  {
    "context": [
      "But I want the output in Json format and the content should come as below.",
      "Seeing below meaning less (unwanted) output which should be removed :",
      "To pair corresponding elements of two arrays and construct an object out of them, we use the `transpose` built-in in conjunction with `add`.",
      "Given `--null-input` and `--raw-input` options on the command line, this JQ program produces your expected output:\n```\n[ input | splits(\" +\") ] as $header | [\n  inputs\n  | [ splits(\" +\") ]\n  | select(. != $header)\n  | [ $header, . ]\n  | [ transpose[] | { (.[0]): .[1] } ]\n  | add\n]\n```"
    ],
    "utterance": "Convert multi-line table output to an array of objects using column headers, omitting any rows that are repeated header lines.",
    "expressions": [
      "[ input | splits(\" +\") ] as $header | [\n  inputs\n  | [ splits(\" +\") ]\n  | select(. != $header)\n  | [ $header, . ]\n  | [ transpose[] | { (.[0]): .[1] } ]\n  | add\n]"
    ],
    "identifier": 63108807
  },
  {
    "context": [
      "I am unable to access any field in the following json file (someconfig.js) which starts with\n\n    window.table = {\n      config: getBootstrapConfig()\n    };\n    \n    window.someConfig = {\n      header: {\n        rui: {\n          iframeUri: \"header/header.html\",\n          divId: \"\",\n          initFnName: \"\"\n        }\n      },\n    ....\n    ...\n    ....\nWhat did I try?\n\n    jq .header someconfig.js\n    parse error: Invalid numeric literal at line 1, column 14\n    \n    jq .window.someConfig someconfig.js\n    \n    parse error: Invalid numeric literal at line 2, column 0\n    \nI am new to jq and have also tried \n\n    jq .['header'] someconfig.js\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?) at <top-level>, line 1:\n    .['header']\n    jq: 1 compile error\n\nHowever I am not able to understand how to fetch fields ex: divId, I want to see \"\".",
      "If you can somehow extract the data component of the JavaScript, you can use a tool such as [tag:hjson] to convert the JSON-like data to JSON, and then use jq.",
      "data | hjson -j | jq .header.rui.iframeUri",
      "You could perhaps use `JSON.stringify` to create a valid JSON string for subsequent processing by jq.",
      "js my.js | jq .someConfig.header.rui.iframeUri"
    ],
    "utterance": "Access the value of 'divId' inside the nested object path header.rui.divId after converting JavaScript-like data to a valid JSON structure.",
    "expressions": [
      ".header.rui.divId",
      ".someConfig.header.rui.divId"
    ],
    "data": [
      {
        "input": {
          "header": {
            "rui": {
              "iframeUri": "header/header.html",
              "divId": "",
              "initFnName": ""
            }
          }
        },
        "output": ""
      },
      {
        "input": {
          "someConfig": {
            "header": {
              "rui": {
                "iframeUri": "header/header.html",
                "divId": "",
                "initFnName": ""
              }
            }
          }
        },
        "output": ""
      }
    ],
    "identifier": 63133465
  },
  {
    "context": [
      "What I want - using jq select and display as a new array all the individual Entries where db[].name \r\nis missing any of \"Business Overview\", \"Load Test\" or \"Performance Monitoring\". In other words, any Entry where all three of them are present in db.[] should be dropped and left only these where any of them is missing.",
      "So, the result of applying such a filter would be displaying the very last Entry with \"Tenant\": \"UT-S1835\", where db[].name is missing \"Load Test\".",
      "map(select( $required - [.db[].name] != []))",
      "[ \"Performance Monitoring\", \"Business Overview\", \"Load Test\" ] as $required\n| map( select( [.db[].name] | any(index($required[]); . == null) ) )",
      "jq 'map( select( [.db[].name]\n   | contains( [\"Business Overview\", \"Performance Monitoring\", \"Load Test\"] )\n   | not ) )'"
    ],
    "utterance": "Select all top-level objects where the 'db' array is missing at least one of the names: 'Business Overview', 'Load Test', or 'Performance Monitoring'.",
    "expressions": [
      "[ \"Business Overview\", \"Load Test\", \"Performance Monitoring\" ] as $required | map(select($required - [.db[].name] != []))",
      "[ \"Performance Monitoring\", \"Business Overview\", \"Load Test\" ] as $required | map( select( [.db[].name] | any(index($required[]); . == null) ) )",
      "map(select( [\"Business Overview\", \"Load Test\", \"Performance Monitoring\"] - [.db[].name] != [] ))",
      "jq 'map( select( [.db[].name] | contains( [\"Business Overview\", \"Performance Monitoring\", \"Load Test\"] ) | not ) )'"
    ],
    "data": [
      {
        "input": [
          {
            "Entry": {
              "Tenant": "CA-T4932",
              "Stage": "prd"
            },
            "db": [
              {
                "id": "xxxxx0001-0a0a-0b0b-0c0c-765434",
                "name": "Business Overview"
              },
              {
                "id": "bbbb0001-0a0a-0b0b-0c0c-6b68706",
                "name": "Performance Monitoring"
              },
              {
                "id": "bbbb0001-0a0a-0b0b-0c0c-f616465",
                "name": "Load Test"
              }
            ]
          },
          {
            "Entry": {
              "Tenant": "NV-R2133",
              "Stage": "dev"
            },
            "db": [
              {
                "id": "ccccc0006-0a0a-0707-0c0c-765434",
                "name": "Business Overview"
              },
              {
                "id": "rrrrr0007-0f0f-0803-0c0c-5e18331",
                "name": "Performance Monitoring"
              },
              {
                "id": "bbbb0001-0a0a-0b0b-0d0d-d439575",
                "name": "Load Test"
              },
              {
                "id": "zzzz0004-0e0e-0ddd-0a0e-ee83005",
                "name": "Home"
              }
            ]
          },
          {
            "Entry": {
              "Tenant": "UT-S1835",
              "Stage": "stg"
            },
            "db": [
              {
                "id": "bcbcb0032-0ccc-4040-1d1d-326923",
                "name": "Business Overview"
              },
              {
                "id": "rrrrr0007-a3b4-1230-0c0c-0e12044",
                "name": "Performance Monitoring"
              },
              {
                "id": "abab0043-0c0f-0dca-0a0e-ee31705",
                "name": "Home"
              }
            ]
          }
        ],
        "output": [
          {
            "Entry": {
              "Tenant": "UT-S1835",
              "Stage": "stg"
            },
            "db": [
              {
                "id": "bcbcb0032-0ccc-4040-1d1d-326923",
                "name": "Business Overview"
              },
              {
                "id": "rrrrr0007-a3b4-1230-0c0c-0e12044",
                "name": "Performance Monitoring"
              },
              {
                "id": "abab0043-0c0f-0dca-0a0e-ee31705",
                "name": "Home"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 63034513
  },
  {
    "context": [
      "What&#39;s the proper way to read a JSON file that has &quot;#&quot; comments?",
      "A file that&#39;s almost JSON, but has `#` comments, *is going to be valid `jq` code*. Thus, if you have an input file created by the shell command:",
      "you can run it as a jq program:",
      "jq -nf input.notjson",
      "...to get as output:",
      "{\n  \"This is a key\": \"This is a value\"\n}"
    ],
    "utterance": "Remove lines and content starting with # comments from input to obtain valid data.",
    "expressions": [
      "jq -nf input.notjson"
    ],
    "data": [
      {
        "input": "{\n  \"This is a key\": \"This is a value\" # this is a comment, which is why this is not JSON\n}",
        "output": "{\n  \"This is a key\": \"This is a value\"\n}"
      }
    ],
    "identifier": 63139542
  },
  {
    "context": [
      "someId=$(curl -sk -H -X POST -d \"fizzbuzz\" \"https://someapi.example.com/v1/orders/fire\" | jq '.someId')",
      "When I run this I get the following output:",
      "...order null placed",
      "To detect *either* an empty string or the non-empty string \"null\", use instead:",
      "if [ -z \"$someId\" ] || [ \"$someId\" = null ]; then",
      "Use the `--exit-status` option, which makes `jq` have a non-zero exit status if the last output value is `false` or `null`.",
      "jq -r --exit-status '.someId'"
    ],
    "utterance": "Detect if the extracted value is either an empty string or the string 'null', or have the command fail if the value is null.",
    "expressions": [
      ".someId",
      "-r --exit-status '.someId'"
    ],
    "identifier": 63140165
  },
  {
    "context": [
      "I am using jq and want to get the \"digest\" elements of the objects where \"name\" follows the regular expression \"^tmp_[0-9a-zA-z]*\"",
      "cat json_file | jq -r 'select(.name|test(\"^tmp_[0-9a-zA-z]*\")) | .images|.[]|.digest'"
    ],
    "utterance": "Get the digest values from objects where name matches the regex ^tmp_[0-9a-zA-z]*.",
    "expressions": [
      "select(.name|test(\"^tmp_[0-9a-zA-z]*\")) | .images|.[]|.digest"
    ],
    "data": [
      {
        "input": [
          {
            "images": [
              {
                "digest": "sha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500"
              }
            ],
            "name": "latest"
          },
          {
            "images": [
              {
                "digest": "sha256:44815925453c50637a53d4d8fb7903d0880fa76bdc37a76b127f68410bc39a35"
              }
            ],
            "name": "tmp_118a872e760bfe4275b489b17ddf2cfbf692ff55"
          },
          {
            "images": [
              {
                "digest": "sha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500"
              }
            ],
            "name": "0.1.0"
          }
        ],
        "output": [
          "sha256:44815925453c50637a53d4d8fb7903d0880fa76bdc37a76b127f68410bc39a35"
        ]
      }
    ],
    "identifier": 63162686
  },
  {
    "context": [
      "My Desired Output in one file from all json files results.",
      "**filename&enValue:confidenceValue**",
      "0001&turbine:100,wind:64,generator:63,device:7,line:7",
      "The jq filter you want can be written as follows:",
      "(input_filename | gsub(\"^\\./|\\.json$\";\"\")) as $fname\n| ( [ .result.tags[] | [.tag.en, (.confidence | floor)] | join(\":\" ) ]\n    | join(\",\") ) as $tags\n| \"\\($fname)&\\($tags)\""
    ],
    "utterance": "Produce an output that lists, for each file, the filename (without .json), followed by all tag.en values and their floored confidence values in the format filename&en1:conf1,en2:conf2,...",
    "expressions": [
      "(input_filename | gsub(\"^\\./|\\.json$\";\"\")) as $fname | ([.result.tags[] | [.tag.en, (.confidence | floor)] | join(\":\")] | join(\",\")) as $tags | \"\\($fname)&\\($tags)\""
    ],
    "data": [
      {
        "input": {
          "result": {
            "tags": [
              {
                "confidence": 100,
                "tag": {
                  "en": "turbine"
                }
              },
              {
                "confidence": 64.8014373779297,
                "tag": {
                  "en": "wind"
                }
              },
              {
                "confidence": 63.3033409118652,
                "tag": {
                  "en": "generator"
                }
              },
              {
                "confidence": 7.27894926071167,
                "tag": {
                  "en": "device"
                }
              },
              {
                "confidence": 7.01708889007568,
                "tag": {
                  "en": "line"
                }
              }
            ]
          },
          "status": {
            "text": "",
            "type": "success"
          }
        },
        "output": "0001&turbine:100,wind:64,generator:63,device:7,line:7"
      }
    ],
    "identifier": 63154459
  },
  {
    "context": [
      "I want to parse below json array and store property of object in array of shell script variable.",
      "###### Acess and parse json file here and store fname inside the name array"
    ],
    "utterance": "Extract all values of the 'fname' property from each object in the 'student_profile' array.",
    "expressions": [
      ".student_profile[].fname"
    ],
    "data": [
      {
        "input": {
          "student_profile": [
            {
              "fname": "abc",
              "lname": "xyz"
            },
            {
              "fname": "def",
              "lname": "pqr"
            }
          ]
        },
        "output": [
          "abc",
          "def"
        ]
      }
    ],
    "identifier": 63188008
  },
  {
    "context": [
      "My end goal is to only extract \"hostnames\" that contain \"cdc.\" I've tried playing with the json select expression but I get a syntax error so I'm sure I'm doing something wrong.",
      "So here in a nutshell is a solution:",
      "{instances:\n [inputs\n | select(length==2 and (.[0][-2:] == [\"ciAttributes\", \"entries\"]))\n | .[-1]\n | fromjson\n | keys_unsorted[]\n | select(test(\"cdc.[.]\"))]}"
    ],
    "utterance": "Extract only the hostnames containing 'cdc.' from the list of hostnames inside the entries property.",
    "expressions": [
      "{instances:[inputs | select(length==2 and (.[0][-2:] == [\"ciAttributes\", \"entries\"])) | .[-1] | fromjson | keys_unsorted[] | select(test(\"cdc.[.]\"))]}"
    ],
    "data": [
      {
        "input": [
          {
            "ciAttributes": {
              "entries": "{\"hostname-cdc1.website.com\":[\"127.0.0.1\"],\"hostname-cdc1-extension.website.com\":[\"127.0.0.1\"]}"
            }
          },
          {
            "ciAttributes": {
              "entries": "{\"hostname-dfw1.website.com\":[\"127.0.0.1\"],\"hostname-dfw1-extension.website.com\":[\"127.0.0.1\"]}"
            }
          },
          {
            "ciAttributes": {
              "entries": "{\"hostname-cdc2.website.com\":[\"127.0.0.1\"],\"hostname-cdc2-extension.website.com\":[\"127.0.0.1\"]}"
            }
          },
          {
            "ciAttributes": {
              "entries": "{\"hostname-dfw2.website.com\":[\"127.0.0.1\"],\"hostname-dfw2-extension.website.com\":[\"127.0.0.1\"]}"
            }
          }
        ],
        "output": {
          "instances": [
            "hostname-cdc1.website.com",
            "hostname-cdc2.website.com"
          ]
        }
      }
    ],
    "identifier": 63163909
  },
  {
    "context": [
      "Trying to extract only key names like \"key-user\" and \"oidc-cid\" using JQ",
      "jq '.[]|keys' data.json",
      "[\n  \"key-user\",\n  \"oidc-cid\"\n]"
    ],
    "utterance": "Extract the immediate property names from the objects in the array, such as \"key-user\" and \"oidc-cid\".",
    "expressions": [
      ".[] | keys"
    ],
    "data": [
      {
        "input": [
          {
            "key-user": {
              "contentType": "",
              "enabled": true,
              "isSecret": true,
              "value": null
            },
            "oidc-cid": {
              "contentType": "",
              "enabled": true,
              "isSecret": true,
              "value": null
            }
          }
        ],
        "output": [
          "key-user",
          "oidc-cid"
        ]
      }
    ],
    "identifier": 63197081
  },
  {
    "context": [
      "I'm seeking a solution on how to add some (not quite so valid) json in a file, to another (valid) json file.",
      "Each time I iterate and call the next set, I'm trying to strip out that information and just append the main data records to the main data records of the first set.",
      "You can turn the invalid JSON from the API response into a valid array by wrapping it in `[...]`. The resulting array can be imported and added directly to the `result` array.",
      "jq --argjson results \"[ $(<new.json) ]\" '.result += $results' original.json"
    ],
    "utterance": "Append all objects from new.json as elements to the result array in original.json, even if new.json is just comma-separated objects and not a valid array.",
    "expressions": [
      "jq --argjson results \"[ $(<new.json) ]\" '.result += $results' original.json"
    ],
    "data": [
      {
        "input": {
          "original.json": {
            "result": [
              {
                "id": "5b5915f4cdb39c7b",
                "kind": "foo",
                "source": "bar",
                "action": "baz",
                "matches": [
                  {
                    "id": "b298ee91704b489b8119c1d604a8308d",
                    "source": "blah",
                    "action": "buzz"
                  }
                ],
                "occurred_at": "date"
              }
            ],
            "result_info": {
              "cursors": {
                "after": "dlipU4c",
                "before": "iLjx06u"
              },
              "scanned_range": {
                "since": "date",
                "until": "date"
              }
            },
            "success": true,
            "errors": [],
            "messages": []
          },
          "new.json": "{\n  \"id\": \"5b5915f4cdb39c7b\",\n  \"kind\": \"foo\",\n  \"source\": \"bar\",\n  \"action\": \"baz\",\n  \"matches\": [\n    {\n      \"id\": \"b298ee91704b489b8119c1d604a8308d\",\n      \"source\": \"blah\",\n      \"action\": \"buzz\"\n    }\n  ],\n  \"occurred_at\": \"date\"\n},\n{\n  \"id\": \"5b5915f4cdb39c7b\",\n  \"kind\": \"foo\",\n  \"source\": \"bar\",\n  \"action\": \"baz\",\n  \"matches\": [\n    {\n      \"id\": \"b298ee91704b489b8119c1d604a8308d\",\n      \"source\": \"blah\",\n      \"action\": \"buzz\"\n    }\n  ],\n  \"occurred_at\": \"date\"\n}"
        },
        "output": {
          "result": [
            {
              "id": "5b5915f4cdb39c7b",
              "kind": "foo",
              "source": "bar",
              "action": "baz",
              "matches": [
                {
                  "id": "b298ee91704b489b8119c1d604a8308d",
                  "source": "blah",
                  "action": "buzz"
                }
              ],
              "occurred_at": "date"
            },
            {
              "id": "5b5915f4cdb39c7b",
              "kind": "foo",
              "source": "bar",
              "action": "baz",
              "matches": [
                {
                  "id": "b298ee91704b489b8119c1d604a8308d",
                  "source": "blah",
                  "action": "buzz"
                }
              ],
              "occurred_at": "date"
            },
            {
              "id": "5b5915f4cdb39c7b",
              "kind": "foo",
              "source": "bar",
              "action": "baz",
              "matches": [
                {
                  "id": "b298ee91704b489b8119c1d604a8308d",
                  "source": "blah",
                  "action": "buzz"
                }
              ],
              "occurred_at": "date"
            }
          ],
          "result_info": {
            "cursors": {
              "after": "dlipU4c",
              "before": "iLjx06u"
            },
            "scanned_range": {
              "since": "date",
              "until": "date"
            }
          },
          "success": true,
          "errors": [],
          "messages": []
        }
      }
    ],
    "identifier": 63078109
  },
  {
    "context": [
      "I would like to collect all the hosts for each dataCenter into a single object like this:\r\n{\r\n \"dataCenter\": \"seapr1\",\r\n \"hosts\": [\r\n    \"seapr1pgdb032\",\r\n    \"seapr1cpndb001\",\r\n    \"seapr1dhcp01\"\r\n  ] \r\n}",
      "GROUPS_BY(inputs; .dataCenter)\r\n| {dataCenter: .[0].dataCenter, hosts: map(.hostname) }"
    ],
    "utterance": "Group records by dataCenter and output, for each group, an object with the dataCenter name and an array of hostnames.",
    "expressions": [
      "GROUPS_BY(inputs; .dataCenter)\n| {dataCenter: .[0].dataCenter, hosts: map(.hostname) }"
    ],
    "data": [
      {
        "input": [
          {
            "hostname": "seapr1pgdb032",
            "ip": "10.215.0.6",
            "dataCenter": "seapr1"
          },
          {
            "hostname": "seapr1cpndb001",
            "ip": "10.203.0.41",
            "dataCenter": "seapr1"
          },
          {
            "hostname": "seapr1dhcp01",
            "ip": "10.205.3.212",
            "dataCenter": "seapr1"
          }
        ],
        "output": [
          {
            "dataCenter": "seapr1",
            "hosts": [
              "seapr1pgdb032",
              "seapr1cpndb001",
              "seapr1dhcp01"
            ]
          }
        ]
      }
    ],
    "identifier": 63199503
  },
  {
    "context": [
      "Can anyone help me get the correct jq command to flatten the below example?",
      "Input:\n\n    [\n        {\n            \"name\": \"level1\",\n            \"children\": [\n                {\n                    \"name\": \"level2\",\n                    \"children\": [\n                        {\n                            \"name\": \"level3-1\",\n                            \"children\": []\n                        },\n                        {\n                            \"name\": \"level3-2\",\n                            \"children\": []\n                        }\n                    ]\n                }\n            ]\n        }\n    ]",
      "Output:\n\n    [\n        {\n            \"displayName\": \"level1\",\n            \"parent\": \"\"\n        },\n        {\n            \"displayName\": \"level2\",\n            \"parent\": \"level1\"\n        },\n        {\n            \"displayName\": \"level3-1\",\n            \"parent\": \"level2\"\n        },\n        {\n            \"displayName\": \"level3-2\",\n            \"parent\": \"level2\"\n        }\n    ]",
      "With a simple recursive function:\n```\ndef f: .name as $parent | .children[] | {$parent, displayName: .name}, f;\n[ {name: \"\", children: .} | f ]\n```",
      "Here's a straightforward solution...If the empty string is really required, one has simply to replace the last non-trivial line above by:\n    | {displayName: .name, parent: (.parent // \"\")}\n"
    ],
    "utterance": "Flatten a hierarchy of objects with 'name' and 'children' keys into a list of objects with 'displayName' set to each name and 'parent' set to the parent's name, using the empty string for the root's parent.",
    "expressions": [
      "def f: .name as $parent | .children[] | {parent: $parent, displayName: .name}, f; [ {name: \"\", children: .} | f ]",
      "[ walk(if type==\"object\" and has(\"children\") then .name as $n | .children |= map(.parent = $n) else . end) | .. | select(type==\"object\" and has(\"name\")) | {displayName: .name, parent: (.parent // \"\")} ]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "level1",
            "children": [
              {
                "name": "level2",
                "children": [
                  {
                    "name": "level3-1",
                    "children": []
                  },
                  {
                    "name": "level3-2",
                    "children": []
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "displayName": "level1",
            "parent": ""
          },
          {
            "displayName": "level2",
            "parent": "level1"
          },
          {
            "displayName": "level3-1",
            "parent": "level2"
          },
          {
            "displayName": "level3-2",
            "parent": "level2"
          }
        ]
      }
    ],
    "identifier": 63194295
  },
  {
    "context": [
      "This is where I'm stuck. How do I include the \"key\" value into each element of the \"value\" array to achieve my desired output.",
      "Here's a very conservative approach:\n```\n.data\n| to_entries[]\n| [.key]\n  + (.value[]\n     | (.statistics | [.wins, .battles])\n       + [.mark_of_mastery, .tank_id])\n```"
    ],
    "utterance": "Produce an array for each record containing the outer object key, statistics.wins, statistics.battles, mark_of_mastery, and tank_id, one per line.",
    "expressions": [
      ".data | to_entries[] | [.key] + (.value[] | (.statistics | [.wins, .battles]) + [.mark_of_mastery, .tank_id])"
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "meta": {
            "count": 10
          },
          "data": {
            "1040918564": [
              {
                "statistics": {
                  "wins": 166,
                  "battles": 441
                },
                "mark_of_mastery": 1,
                "tank_id": 9505
              },
              {
                "statistics": {
                  "wins": 154,
                  "battles": 325
                },
                "mark_of_mastery": 1,
                "tank_id": 47105
              }
            ],
            "1040836357": [
              {
                "statistics": {
                  "wins": 216,
                  "battles": 490
                },
                "mark_of_mastery": 1,
                "tank_id": 47105
              },
              {
                "statistics": {
                  "wins": 114,
                  "battles": 254
                },
                "mark_of_mastery": 2,
                "tank_id": 7969
              }
            ]
          }
        },
        "output": [
          [
            1040918564,
            166,
            441,
            1,
            9505
          ],
          [
            1040918564,
            154,
            325,
            1,
            47105
          ],
          [
            1040836357,
            216,
            490,
            1,
            47105
          ],
          [
            1040836357,
            114,
            254,
            2,
            7969
          ]
        ]
      }
    ],
    "identifier": 63207815
  },
  {
    "context": [
      "if a key is prefixed with \"NUMBER::\" I'd like the following to happen:",
      "JQ will remove the \"NUMBER::\" prefix from the key name.",
      "JQ will convert the value from a string to a number.",
      "Here is what I'd like to do with JQ:\n1. JQ will copy over the key/value pairs for the majority of elements in the JSON \"as is\".  If there is no \"NUMBER::\" prefix, they are copied over \"as is\".\n2. However, if a key is prefixed with \"NUMBER::\" ...",
      "Select each entry with a key starting with `NUMBER::` and update it to remove that prefix and convert the value to a number.",
      "with_entries(\n  select(.key | startswith(\"NUMBER::\")) |= (\n    (.key   |= ltrimstr(\"NUMBER::\")) |\n    (.value |= tonumber)\n  )\n)"
    ],
    "utterance": "Convert all key-value pairs whose key starts with 'NUMBER::' so that the prefix is removed from the key and the value is cast to a number; all other pairs are left unchanged.",
    "expressions": [
      "with_entries(\n  select(.key | startswith(\"NUMBER::\")) |= (\n    (.key   |= ltrimstr(\"NUMBER::\")) |\n    (.value |= tonumber)\n  )\n)"
    ],
    "data": [
      {
        "input": {
          "NUMBER::AUTOSCALING_MAX_CAPACITY": "12",
          "SERVICE_PLATFORM_VERSION": "1.3.0",
          "HEALTH_CHECK_PROTOCOL": "HTTPS",
          "NUMBER::HEALTH_CHECK_UNHEALTHY_THRESHOLD_COUNT": "2"
        },
        "output": {
          "AUTOSCALING_MAX_CAPACITY": 12,
          "SERVICE_PLATFORM_VERSION": "1.3.0",
          "HEALTH_CHECK_PROTOCOL": "HTTPS",
          "HEALTH_CHECK_UNHEALTHY_THRESHOLD_COUNT": 2
        }
      }
    ],
    "identifier": 63208694
  },
  {
    "context": [
      "In its manual, it says -e 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.",
      "$ echo false | jq -e .\nfalse",
      "$ echo '{ \"foo\": false }' | jq -e .foo\nfalse",
      "$ echo null | jq -e .\nnull",
      "$ echo '{ \"foo\": null }' | jq -e .foo\nnull",
      "$ echo '{ }' | jq -e .foo\nnull",
      "$ echo '{ \"foo\": false }' | jq -e '.bar?'\nnull"
    ],
    "utterance": "Check if the last value in the data is false or null and set a non-zero exit code if so.",
    "expressions": [
      "jq -e .",
      "jq -e .foo",
      "jq -e '.bar?'"
    ],
    "data": [
      {
        "input": false,
        "output": false
      },
      {
        "input": {
          "foo": false
        },
        "output": false
      },
      {
        "input": null,
        "output": null
      },
      {
        "input": {
          "foo": null
        },
        "output": null
      },
      {
        "input": {},
        "output": null
      },
      {
        "input": {
          "foo": false
        },
        "output": null
      }
    ],
    "identifier": 63210383
  },
  {
    "context": [
      "And I want to get the output object with properties **\"name\"**, **\"id\"**, **\"scopes\"**. Where \"scopes\" is an array of unique values.",
      "I can get these properties separately. But I don't know how to combine them together.",
      "\".config\n| (\n  .endpoints\n  | map(.extra[\"namespace_auth.com\"] | select(.scope) | .[])\n  | unique\n) as $s\n| .extra[\"auth_namespace.com\"] | select(.name)\n| {name, id, scopes: $s}\"",
      "\".config\n| (.extra.\"auth_namespace.com\" | {id, name}) \n  + {scopes: .endpoints\n             | map( select(has(\"extra\"))\n                    | .extra.\"namespace_auth.com\"\n                    | select(has(\"scope\"))\n                    | .scope )\n             | unique }\""
    ],
    "utterance": "Produce an object containing name and id from extra.auth_namespace.com and an array of unique scopes found in the endpoints' extra.namespace_auth.com.scope fields.",
    "expressions": [
      ".config\n| (\n  .endpoints\n  | map(.extra[\"namespace_auth.com\"] | select(.scope) | .[])\n  | unique\n) as $s\n| .extra[\"auth_namespace.com\"] | select(.name)\n| {name, id, scopes: $s}",
      ".config\n| (.extra.\"auth_namespace.com\" | {id, name}) \n  + {scopes: .endpoints\n             | map( select(has(\"extra\"))\n                    | .extra.\"namespace_auth.com\"\n                    | select(has(\"scope\"))\n                    | .scope )\n             | unique }"
    ],
    "data": [
      {
        "input": {
          "config": {
            "extra": {
              "auth_namespace.com": {
                "name": "some_name",
                "id": 1
              }
            },
            "endpoints": [
              {
                "extra": {
                  "namespace_auth.com": {
                    "scope": "scope1"
                  }
                }
              },
              {
                "extra": {
                  "namespace_auth.com": {
                    "scope": "scope2"
                  }
                }
              },
              {
                "extra": {
                  "namespace_auth.com": {
                    "scope": "scope2"
                  }
                }
              },
              {
                "extra": {
                  "namespace_1.com": {}
                }
              },
              {
                "other": "value"
              }
            ]
          }
        },
        "output": {
          "name": "some_name",
          "id": 1,
          "scopes": [
            "scope1",
            "scope2"
          ]
        }
      }
    ],
    "identifier": 63210290
  },
  {
    "context": [
      "My input:\n{\n  \"accounts\": [\n    \"bob.doe\",\n    \"joe.gomez\",\n    \"bill.murr\"\n  ]\n}",
      "Desired output:\n\nbob.doe test\njoe.gomez test\nbill.murr test",
      "$ jq -r '\"\\(.accounts[]) test\"' file"
    ],
    "utterance": "Return each element in the 'accounts' array with ' test' appended to its value, outputting one per line.",
    "expressions": [
      ".accounts[] + \" test\"",
      "\"\\(.accounts[]) test\""
    ],
    "data": [
      {
        "input": {
          "accounts": [
            "bob.doe",
            "joe.gomez",
            "bill.murr"
          ]
        },
        "output": [
          "bob.doe test",
          "joe.gomez test",
          "bill.murr test"
        ]
      }
    ],
    "identifier": 63233442
  },
  {
    "context": [
      "So this is my JSON, and I just want to extract the **name** keys in all the sub-objects",
      "There are multiple ways to get this done. One way is map the path leading up to the `name` key and get the value of that path",
      "(paths | select( .[-1] == \"name\")) as $path | getpath($path)",
      "or as noted in the comments, just use the recursive descent builtin `recurse` and select objects with fields containing `.name` key",
      "recurse | select(has(\"name\")?).name"
    ],
    "utterance": "Extract all values of keys named name at any depth within the structure.",
    "expressions": [
      "(paths | select( .[-1] == \"name\")) as $path | getpath($path)",
      "recurse | select(has(\"name\")?).name"
    ],
    "data": [
      {
        "input": {
          "checkpassword": {
            "checkpassword": {
              "containers": [
                {
                  "name": "checkpassword",
                  "exists": "true",
                  "running": "true"
                }
              ],
              "projectdir": "true",
              "nginxdef": "true"
            }
          },
          "reverse_proxy": {
            "reverse_proxy": {
              "containers": [
                {
                  "name": "reverse_proxy",
                  "exists": "true",
                  "running": "true"
                }
              ],
              "projectdir": "true"
            }
          }
        },
        "output": [
          "checkpassword",
          "reverse_proxy"
        ]
      }
    ],
    "identifier": 63227372
  },
  {
    "context": [
      "I know I can retrieve the System ROM version for DL380 Gen 10s with: jq -r '.members[]  | select(.serverModel == \"Proliant DL380 Gen10\") |  .components[] | select(.componentName == \"System ROM\") |.componentVersion' firmware, but I also wanted to print the serverName along with the system ROM version.",
      "$ cat stuff.jq",
      ".members[]",
      "   | select(.serverModel == \"Proliant DL380 Gen10\")",
      "   | {",
      "       name: .serverName,",
      "       rom: ( .components[] | select(.componentName == \"System ROM\") | .componentVersion )",
      "       }",
      "   | \"The ROM version for \\(.name) is \\(.rom)\"",
      "$ jq -rf stuff.jq firmware.json ",
      "The ROM version for bb-r2-n12-ilo is U30 v1.46 (10/02/2018)",
      "The ROM version for bb-r5-n10-ilo is U30 v1.36 (02/15/2018)"
    ],
    "utterance": "For each server with model 'Proliant DL380 Gen10', print both the serverName and its System ROM version.",
    "expressions": [
      ".members[] | select(.serverModel == \"Proliant DL380 Gen10\") | {name: .serverName, rom: (.components[] | select(.componentName == \"System ROM\") | .componentVersion)} | \"The ROM version for \\(.name) is \\(.rom)\"",
      ".members[] | select(.serverModel == \"Proliant DL380 Gen10\") | .serverName as $name | .components[] | select(.componentName == \"System ROM\") | \"The ROM version for \\\\($name) is \\\\(.componentVersion)\""
    ],
    "data": [
      {
        "input": {
          "uri": "/rest/server-hardware/*/firmware?start=0&count=32",
          "total": 102,
          "start": 0,
          "prevPageUri": null,
          "type": "sever-firmwareinventory-list-1",
          "category": "server-hardware",
          "count": 32,
          "members": [
            {
              "uri": "/rest/server-hardware/37383638-5A43-3338-313356585742/firmware",
              "type": "server-hardware-firmware-1",
              "category": "server-hardware",
              "serverHardwareUri": "/rest/server-hardware/37383638-5A43-3338-313356585742",
              "serverName": "bb-r2-n12-ilo",
              "serverModel": "Proliant DL380 Gen10",
              "components": [
                {
                  "componentVersion": "4.0.4.288",
                  "componentLocation": "System Board",
                  "componentName": "Server Platform Services (SPS) Firmware",
                  "componentKey": "b34e5677-21dc-45d3-872b-42f76fee9053"
                },
                {
                  "componentVersion": "U30 v1.46 (10/02/2018)",
                  "componentLocation": "System Board",
                  "componentName": "System ROM",
                  "componentKey": "aa148d2e-6e09-453e-bc6f-62baa5f5ccc4"
                }
              ],
              "created": "2020-07-26T22:01:54.679Z"
            },
            {
              "uri": "/rest/server-hardware/37383638-5A43-3338-313052304C4A/firmware",
              "type": "server-hardware-firmware-1",
              "category": "server-hardware",
              "serverHardwareUri": "/rest/server-hardware/37383638-5A43-3338-313052304C4A",
              "serverName": "bb-r5-n10-ilo",
              "serverModel": "Proliant DL380 Gen10",
              "components": [
                {
                  "componentVersion": "4.1.4.296",
                  "componentLocation": "System Board",
                  "componentName": "Server Platform Services (SPS) Firmware",
                  "componentKey": "b34e5677-21dc-45d3-872b-42f76fee9053"
                },
                {
                  "componentVersion": "U30 v1.36 (02/15/2018)",
                  "componentLocation": "System Board",
                  "componentName": "System ROM",
                  "componentKey": null
                }
              ],
              "created": "2020-07-26T22:01:54.679Z"
            },
            {
              "uri": "/rest/server-hardware/37313438-3033-5A43-3338-30384D533730/firmware",
              "type": "server-hardware-firmware-1",
              "category": "server-hardware",
              "serverHardwareUri": "/rest/server-hardware/37313438-3033-5A43-3338-30384D533730",
              "serverName": "bb-r3-n1-ilo",
              "serverModel": "Proliant DL560 Gen10",
              "components": [
                {
                  "componentVersion": "4.1.4.296",
                  "componentLocation": "System Board",
                  "componentName": "Server Platform Services (SPS) Firmware",
                  "componentKey": "b34e5677-21dc-45d3-872b-42f76fee9053"
                },
                {
                  "componentVersion": "U34 v2.10 (05/21/2019)",
                  "componentLocation": "System Board",
                  "componentName": "System ROM",
                  "componentKey": "aa148d2e-6e08-453e-bc6f-63baa5f5ccc4"
                }
              ],
              "created": "2020-07-26T22:01:54.679Z"
            }
          ],
          "modified": "2020-07-27T09:30:55.882Z",
          "nextPageUri": null
        },
        "output": [
          "The ROM version for bb-r2-n12-ilo is U30 v1.46 (10/02/2018)",
          "The ROM version for bb-r5-n10-ilo is U30 v1.36 (02/15/2018)"
        ]
      }
    ],
    "identifier": 63113661
  },
  {
    "context": [
      "I want my output to be without any new line and as below, separated by space and no space after the last word (server3 in this case)",
      "I don't want to do pipe after jq command and obtain the output with sed and tr commands. I want to achieve this with jq command only.",
      "jq -r '.[] | select(.property == \"ENABLED\") |.name' input.json",
      "You're pretty close to there! In your case, the join function may help:",
      "jq -r '[.[]|select(.property==\"ENABLED\")|.name]|join(\" \")' input.json"
    ],
    "utterance": "Output all objects with property equal to ENABLED as a single line of space-separated names with no trailing space.",
    "expressions": [
      "[.[] | select(.property==\"ENABLED\") | .name] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "server1": {
            "name": "server1",
            "property": "ENABLED"
          },
          "server2": {
            "name": "server2",
            "property": "ENABLED"
          },
          "server3": {
            "name": "server3",
            "property": "ENABLED"
          }
        },
        "output": "server1 server2 server3"
      }
    ],
    "identifier": 63238759
  },
  {
    "context": [
      "ie. how to iterate over top level array `countries`, pick field `countryName` from it, and iterate over  field `cities` contained in `countries` array elements and pick `cityName` from it, etc. to have resultant array of triplets, which can be then processed into desired output text.",
      "jq '.countries[] | .countryName as $country| .cities[] | .cityName as $city | .streets[] | $country+\" \"+$city+\" \"+.streetName ' < /tmp/sampleData.json",
      "jq '[(.countries[] | .countryName as $country| .cities[] | .cityName as $city | .streets[] | [$country,$city,.streetName])] | .[] | @csv' < /tmp/sampleData.json ",
      "| [$country, $city, .streetName]\n| @csv",
      "| [$country, $city, .streetName]\n| map(q)\n| join(\",\")"
    ],
    "utterance": "Extract all country, city, and street name combinations as triplets in row format.",
    "expressions": [
      ".countries[] | .countryName as $country | .cities[] | .cityName as $city | .streets[] | $country + \" \" + $city + \" \" + .streetName",
      ".countries[] | .countryName as $country | .cities[] | .cityName as $city | .streets[] | [$country, $city, .streetName] | @csv",
      ".countries[] | .countryName as $country | .cities[] | .cityName as $city | .streets[] | [$country, $city, .streetName] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "countries": [
            {
              "countryName": "CZ",
              "cities": [
                {
                  "cityName": "Prague",
                  "streets": [
                    {
                      "streetName": "Norsk\u00e1"
                    },
                    {
                      "streetName": "Slovensk\u00e1"
                    }
                  ]
                }
              ]
            },
            {
              "countryName": "FR",
              "cities": [
                {
                  "cityName": "Paris",
                  "streets": [
                    {
                      "streetName": "rue piat"
                    },
                    {
                      "streetName": "rue lesage"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "CZ Prague Norsk\u00e1",
          "CZ Prague Slovensk\u00e1",
          "FR Paris rue piat",
          "FR Paris rue lesage"
        ]
      }
    ],
    "identifier": 63228971
  },
  {
    "context": [
      "regarding the updated question, which asked about using capture, the solution looks like this:",
      "jq '.arr |= map(.a.id as $id | .a.b.c[].data[].something |= ($id | capture(\"(?<a>[a-zA-z]*)(?<b>.*)\") | (.a+.b+.a)  ) ) ' < a.json > c.json",
      "about regex rule: everything from start of `id` until first decimal has to be  appended to the `id` to produce `something`.",
      "So here within brackets we expand variable `$id`, capture regex, and from new context produced by `capture`, we produce new value for `something` using string concatenation `(.a+.b+.a)`."
    ],
    "utterance": "Update each .arr[].a.b.c[].data[].something to be the .a.id concatenated with its initial non-numeric part, using a regular expression with capture.",
    "expressions": [
      ".arr |= map(.a.id as $id | .a.b.c[].data[].something |= ($id | capture(\"(?<a>[A-Za-z]*)(?<b>.*)\") | (.a + .b + .a)))"
    ],
    "data": [
      {
        "input": {
          "arr": [
            {
              "a": {
                "id": "a100",
                "b": {
                  "c": [
                    {
                      "data": [
                        {
                          "something": null
                        }
                      ]
                    }
                  ]
                }
              }
            },
            {
              "a": {
                "id": "bPleaseUseRegex100",
                "b": {
                  "c": [
                    {
                      "data": [
                        {
                          "something": null
                        }
                      ]
                    }
                  ]
                }
              }
            }
          ]
        },
        "output": {
          "arr": [
            {
              "a": {
                "id": "a100",
                "b": {
                  "c": [
                    {
                      "data": [
                        {
                          "something": "a100a"
                        }
                      ]
                    }
                  ]
                }
              }
            },
            {
              "a": {
                "id": "bPleaseUseRegex100",
                "b": {
                  "c": [
                    {
                      "data": [
                        {
                          "something": "bPleaseUseRegex100bPleaseUseRegex"
                        }
                      ]
                    }
                  ]
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 63235633
  },
  {
    "context": [
      "result=$($data | jq --arg Name \"$1\" -r '.items[] | select(.app==$Name) | .name')",
      "result=$(echo $data | jq --arg Name \"$1\" -r '.items[] | select(.app==$Name) | .name')",
      "result=$( curl -sb -H $url |  jq --arg Name \"$1\" -r '.items[] | select(.app==$Name) | .name')"
    ],
    "utterance": "Extract the name field of each item where app equals the provided Name variable.",
    "expressions": [
      ".items[] | select(.app==$Name) | .name"
    ],
    "identifier": 63249171
  },
  {
    "context": [
      "However I want to extract the bodyText. How would I write a query in the same format to grab the bodyText?",
      "A jq query for retrieving the .bodyText values as a stream is:\r\n\r\n    .response.results[] | .fields.bodyText"
    ],
    "utterance": "Extract the bodyText field for each object inside the response.results array.",
    "expressions": [
      ".response.results[] | .fields.bodyText"
    ],
    "data": [
      {
        "input": {
          "response": {
            "status": "ok",
            "userTier": "developer",
            "total": 18398,
            "startIndex": 1,
            "pageSize": 10,
            "currentPage": 1,
            "pages": 1840,
            "orderBy": "relevance",
            "results": [
              {
                "id": "world/2020/jul/03/coronavirus-the-week-explained",
                "type": "article",
                "sectionId": "world",
                "sectionName": "World news",
                "webPublicationDate": "2020-07-03T11:03:46Z",
                "webTitle": "Coronavirus: the week explained",
                "webUrl": "https://www.theguardian.com/world/2020/jul/03/coronavirus-the-week-explained",
                "apiUrl": "https://content.guardianapis.com/world/2020/jul/03/coronavirus-the-week-explained",
                "fields": {
                  "bodyText": "words"
                },
                "isHosted": false,
                "pillarId": "pillar/news",
                "pillarName": "News"
              },
              {
                "id": "music/2020/jun/10/saving-classical-music-from-coronavirus",
                "type": "article",
                "sectionId": "music",
                "sectionName": "Music",
                "webPublicationDate": "2020-06-10T17:38:03Z",
                "webTitle": "Saving classical music from coronavirus | Letters",
                "webUrl": "https://www.theguardian.com/music/2020/jun/10/saving-classical-music-from-coronavirus",
                "apiUrl": "https://content.guardianapis.com/music/2020/jun/10/saving-classical-music-from-coronavirus",
                "fields": {
                  "bodyText": "more words"
                },
                "isHosted": false,
                "pillarId": "pillar/arts",
                "pillarName": "Arts"
              }
            ]
          }
        },
        "output": [
          "words",
          "more words"
        ]
      }
    ],
    "identifier": 63239004
  },
  {
    "context": [
      "I want a jq filter that gives me the same structure, but only the sub-objects that have the \"prop_3\" entry:",
      "But can't figure out how to extend this further down the hierarchy.",
      "Just.. `select` them?",
      "```\n.[][] |= select(has(\"prop_3\"))\n```"
    ],
    "utterance": "Return an object where for each top-level key, only sub-objects containing the key 'prop_3' are kept.",
    "expressions": [
      ".[][] |= select(has(\"prop_3\"))"
    ],
    "data": [
      {
        "input": {
          "item-1": {
            "sub-item-1": {
              "prop_1": 0,
              "prop_2": "bar"
            },
            "sub-item-2": {
              "prop_1": 0,
              "prop_2": "bar",
              "prop_3": "OK"
            }
          },
          "item-2": {
            "sub-item-1": {
              "prop_3": "OK"
            }
          }
        },
        "output": {
          "item-1": {
            "sub-item-2": {
              "prop_1": 0,
              "prop_2": "bar",
              "prop_3": "OK"
            }
          },
          "item-2": {
            "sub-item-1": {
              "prop_3": "OK"
            }
          }
        }
      }
    ],
    "identifier": 63248435
  },
  {
    "identifier": 63266261
  },
  {
    "context": [
      "I need to filter out all metadata elements that have an InlineBinary property.",
      "I want to transform this to:\n\n{\n    \"00080005\": {\n        \"vr\": \"CS\",\n        \"Value\": [\"ISO_IR 192\"]\n    }\n}\n",
      "When selecting key-value pairs, `with_entries` is often the tool of choice:\n\n    with_entries( select(.value | has(\"InlineBinary\") | not) )"
    ],
    "utterance": "Keep only top-level elements that do not have the InlineBinary property.",
    "expressions": [
      "with_entries(select(.value | has(\"InlineBinary\") | not))"
    ],
    "data": [
      {
        "input": {
          "00080005": {
            "vr": "CS",
            "Value": [
              "ISO_IR 192"
            ]
          },
          "00291010": {
            "vr": "OB",
            "InlineBinary": "Zm9vYmFyCg=="
          }
        },
        "output": {
          "00080005": {
            "vr": "CS",
            "Value": [
              "ISO_IR 192"
            ]
          }
        }
      }
    ],
    "identifier": 63255413
  },
  {
    "context": [
      "I need to append content in my primary file with information from a secondary file.",
      "The elements order is related. The first object \"fixedKey\" corresponds to \"dynamic-parent-key-1\" and so on. The first file is JSON compliant and the second is not, it is just a list of JSON objects saved on a common file.",
      "I need an output file (or just update the first one) so it looks ideally like this:\n\n{\n  \"master-key\": {\n    \"dynamic-parent-key-1\": {\n      \"key1\": \"value1\",\n      \"key2\": \"value2\",\n      \"array1\": [\n        \"array-value-1\",\n        \"array-value-2\"\n      ],\n      \"fixedKey\": [ ... ]\n    },\n    \"dynamic-parent-key-2\": {\n      ...\n    }\n  }\n}\n",
      "jq -n '{ \"master-key\": input | add | map_values(. + input) }' file1.json file2.json",
      "The first `input` call loads the array from your primary file and `add` converts this array to an object. Then `map_values` merges each sub-object with a new object loaded from the input stream (now on the secondary file) by subsequent `input` calls."
    ],
    "utterance": "Combine an array with corresponding objects from another file, merging each object in order, and nest the result under a top-level key named \"master-key\".",
    "expressions": [
      "jq -n '{ \"master-key\": input | add | map_values(. + input) }' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "dynamic-parent-key-1": {
                "key1": "value1",
                "key2": "value2",
                "array1": [
                  "array-value-1",
                  "array-value-2"
                ]
              }
            },
            {
              "dynamic-parent-key-2": {
                "key1": "value1",
                "key2": "value2",
                "array1": [
                  "array-value-1"
                ]
              }
            }
          ],
          {
            "fixedKey": [
              {
                "Key": "A",
                "Value": "abc"
              },
              {
                "Key": "B",
                "Value": "xyz"
              },
              {
                "Key": "C",
                "Value": "asd"
              }
            ]
          },
          {
            "fixedKey": [
              {
                "Key": "A",
                "Value": "aaa"
              },
              {
                "Key": "B",
                "Value": "bbb"
              },
              {
                "Key": "C",
                "Value": "ccc"
              }
            ]
          }
        ],
        "output": {
          "master-key": {
            "dynamic-parent-key-1": {
              "key1": "value1",
              "key2": "value2",
              "array1": [
                "array-value-1",
                "array-value-2"
              ],
              "fixedKey": [
                {
                  "Key": "A",
                  "Value": "abc"
                },
                {
                  "Key": "B",
                  "Value": "xyz"
                },
                {
                  "Key": "C",
                  "Value": "asd"
                }
              ]
            },
            "dynamic-parent-key-2": {
              "key1": "value1",
              "key2": "value2",
              "array1": [
                "array-value-1"
              ],
              "fixedKey": [
                {
                  "Key": "A",
                  "Value": "aaa"
                },
                {
                  "Key": "B",
                  "Value": "bbb"
                },
                {
                  "Key": "C",
                  "Value": "ccc"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 63237346
  },
  {
    "context": [
      "Now, I want to use jq to return boolean value if uri is present or not.",
      "The `has` function does the job:\r\n```bash\r\njq '.results|map(has(\"uri\"))|.[]'\r\n```",
      "`map` the `has` function on `.results`."
    ],
    "utterance": "Return true if any element in the 'results' array contains the field 'uri', otherwise return false.",
    "expressions": [
      ".results | map(has(\"uri\")) | any"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "uri": "www.xxx.com"
            }
          ]
        },
        "output": true
      },
      {
        "input": {
          "results": []
        },
        "output": false
      }
    ],
    "identifier": 63286182
  },
  {
    "context": [
      "I have script:",
      "I need help to sort it out by load.",
      "Try",
      "jq --raw-output 'map(select(.locations[].country.city.name == \"Bangkok\"))| sort_by(.load)[] | \"  Server: \\(.name)\\nHostname: \\(.hostname)\\n      IP: \\(.station)\\n Country: \\(.locations[0].country.name)\\n    City: \\(.locations[0].country.city.name)\\n    Load: \\(.load)\\n\"'",
      "The main program can then be written as follows:",
      "map( select(.locations[].country.city.name == \"Bangkok\") ) | sort_by(.load)[] | {\"Server\": .name,  \"Hostname\": .hostname,  \"IP\": .station, \"Country\": .locations[0].country.name, \"City\": .locations[0].country.city.name, \"Load\": .load  } | format, \"\"'"
    ],
    "utterance": "Display all server entries with city name Bangkok, sorted in ascending order by the load field.",
    "expressions": [
      "map(select(.locations[].country.city.name == \"Bangkok\")) | sort_by(.load)[] | \"  Server: \\(.name)\\nHostname: \\(.hostname)\\n      IP: \\(.station)\\n Country: \\(.locations[0].country.name)\\n    City: \\(.locations[0].country.city.name)\\n    Load: \\(.load)\\n\"",
      "map(select(.locations[].country.city.name == \"Bangkok\")) | sort_by(.load)[] | {\"Server\": .name, \"Hostname\": .hostname, \"IP\": .station, \"Country\": .locations[0].country.name, \"City\": .locations[0].country.city.name, \"Load\": .load} | format, \"\""
    ],
    "identifier": 63253610
  },
  {
    "context": [
      "I need to check if any of the `networkConfiguration.subnetID` under the array `value` contains the string `batch`. If yes then nothing needs to be done. Else, append `-batch` to the existing value. In this case, only the second `networkConfiguration.subnetID` of the array should be updated.",
      "You don't need to use the whole path of `subnetId` again. You've already selected that node from the pipeline before. Just use the `+=` append operator to suffix the required string",
      "( .parameters.batchPools.value[] | \n  select(.networkConfiguration.subnetId | contains(\"batch\") | not) | \n  .networkConfiguration.subnetId ) += \"-batch\""
    ],
    "utterance": "Append '-batch' to each networkConfiguration.subnetId under parameters.batchPools.value where the value does not already contain 'batch'.",
    "expressions": [
      "( .parameters.batchPools.value[] | select(.networkConfiguration.subnetId | contains(\"batch\") | not) | .networkConfiguration.subnetId ) += \"-batch\""
    ],
    "data": [
      {
        "input": {
          "$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "batchPools": {
              "value": [
                {
                  "networkConfiguration": {
                    "subnetId": "/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name-batch",
                    "subnetAddressPrefix": ""
                  }
                },
                {
                  "networkConfiguration": {
                    "subnetId": "/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name",
                    "subnetAddressPrefix": ""
                  }
                }
              ]
            }
          }
        },
        "output": {
          "$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "batchPools": {
              "value": [
                {
                  "networkConfiguration": {
                    "subnetId": "/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name-batch",
                    "subnetAddressPrefix": ""
                  }
                },
                {
                  "networkConfiguration": {
                    "subnetId": "/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name-batch",
                    "subnetAddressPrefix": ""
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 63259559
  },
  {
    "context": [
      "I want to know from which country \"Jan\" is (Belgium).",
      "Get the path to the entry whose `first_name` is `Jan` as an array, and extract the country name from it.",
      "path(.[][] | select(.first_name == \"Jan\"))[0]",
      "The following prevents the production of repetitions when \"Jan\" is the first name of several individuals, and is also more efficient than alternatives that unconditionally scan through all \"first_name\" values:",
      "to_entries[] | select( any(.value[]; .first_name==\"Jan\")).key"
    ],
    "utterance": "Find the country name whose people list includes a person with first_name equal to Jan.",
    "expressions": [
      "path(.[][] | select(.first_name == \"Jan\"))[0]",
      "to_entries[] | select( any(.value[]; .first_name==\"Jan\")).key"
    ],
    "data": [
      {
        "input": {
          "Belgium": [
            {
              "first_name": "Jan",
              "last_name": "Molenaar"
            },
            {
              "first_name": "Piet",
              "last_name": "Hoogenboom"
            }
          ],
          "Germany": [
            {
              "first_name": "Herman",
              "last_name": "Bret"
            },
            {
              "first_name": "Sanne",
              "last_name": "Klepper"
            }
          ]
        },
        "output": "Belgium"
      }
    ],
    "identifier": 63301629
  },
  {
    "context": [
      "I am trying to read the object contained in 'folder' into a variable $var as an array. Desired output - $var contains the following:\n[\n  {\n    \"name\": \"Desktop\",\n    \"path\": \"Users/user/Desktop\",\n    \"executable\": false\n  }\n]",
      "Is this what you were expecting ?\n\n$ var=\"$(jq \"[.folder]\" test.json)\"\n$ echo \"$var\"\n[\n  {\n    \"name\": \"Desktop\",\n    \"path\": \"Users/user/Desktop\",\n    \"executable\": false\n  }\n]"
    ],
    "utterance": "Select the 'folder' object and wrap it in an array.",
    "expressions": [
      "[.folder]"
    ],
    "data": [
      {
        "input": {
          "folder": {
            "name": "Desktop",
            "path": "Users/user/Desktop",
            "executable": false
          }
        },
        "output": [
          {
            "name": "Desktop",
            "path": "Users/user/Desktop",
            "executable": false
          }
        ]
      }
    ],
    "identifier": 63347170
  },
  {
    "context": [
      "I am trying to also add it where for example it only would pull data that contains the words (\"abc\") from `column3`.",
      "I added `|select(.column3| startswith ('ab'))` so the full command is:",
      "It\u2019s easier to filter before converting the object to an array for `@csv`:",
      "jq -r 'select(.column3 | startswith(\"ab\"))\n          | [.column1, .column2, .column3]\n          | @csv' data.json",
      "But if you do want to convert to an array first, you then have to `select` using the appropriate array index:",
      "jq -r '[.column1, .column2, .column3]\n       | select(.[2] | startswith(\"ab\"))\n       | @csv' data.json"
    ],
    "utterance": "Filter objects where column3 starts with 'ab', then output column1, column2, and column3 fields as CSV.",
    "expressions": [
      "select(.column3 | startswith(\"ab\")) | [.column1, .column2, .column3] | @csv",
      "[.column1, .column2, .column3] | select(.[2] | startswith(\"ab\")) | @csv"
    ],
    "data": [
      {
        "input": {
          "column1": "hello",
          "column2": "bye",
          "column3": "abc"
        },
        "output": "\"hello\",\"bye\",\"abc\""
      }
    ],
    "identifier": 63319824
  },
  {
    "context": [
      "I would like to aggregate two or more files into a single json, and aggregate arrays under a same key.",
      "But this requires me to know the **shapes** attribute and hardcode it. Is there a simple way I can get the same result without ever using the key name explicitly?",
      "Try the following code. This can handle any number of files. All inputs are assumed to be json objects with all values inside as arrays. All such arrays are aggregated after grouping by keys. It outputs an object which has keys associated with corresponding aggregated arrays.",
      "jq -s 'map(to_entries)|add|group_by(.key)|\n        map( { \"key\": (.[0].key), \"value\": (map(.value)|add)})|\n        from_entries' file1.json file2.json",
      "Here is a solution that also solves a more general problem: first, it handles arbitrarily many input files; and second, it forms the \"sum\" by key, for every key, on the assumption that every top-level key is array-valued.",
      "# the values at each key are assumed to be arrays\ndef aggregate(stream): \n  reduce stream as $o ({}; \n    reduce ($o|keys_unsorted[]) as $k (.; \n      .[$k] += $o[$k] ));",
      "To avoid \"slurping\", we will use `inputs`:\n\n    aggregate(inputs)",
      "The invocation must therefore use the -n command-line option:\n\n    jq -n -f program.jq *.json"
    ],
    "utterance": "Aggregate objects from multiple files by merging arrays under each top-level key, without specifying the key names explicitly.",
    "expressions": [
      "jq -s 'map(to_entries)|add|group_by(.key)|map({ \"key\": (.[0].key), \"value\": (map(.value)|add)})|from_entries' file1.json file2.json",
      "def aggregate(stream): reduce stream as $o ({}; reduce ($o|keys_unsorted[]) as $k (.; .[$k] += $o[$k] )); aggregate(inputs)",
      "reduce inputs as $in (null;\n   ($in|keys_unsorted[0]) as $k | { ($k): (.[$k] + $in[$k]) })",
      "reduce inputs as $in (null; ($in|keys_unsorted[0]) as $k | .[$k] += $in[$k] )"
    ],
    "data": [
      {
        "input": [
          {
            "shapes": [
              {
                "id": "1",
                "name": "circle"
              },
              {
                "id": "2",
                "name": "square"
              }
            ]
          },
          {
            "shapes": [
              {
                "id": "3",
                "name": "triangle"
              }
            ]
          }
        ],
        "output": {
          "shapes": [
            {
              "id": "1",
              "name": "circle"
            },
            {
              "id": "2",
              "name": "square"
            },
            {
              "id": "3",
              "name": "triangle"
            }
          ]
        }
      }
    ],
    "identifier": 63264954
  },
  {
    "context": [
      "But if I execute\n\necho '{\"foo\": \"bar\", \"baz\": null}' | jq '.hello'\n\nI also receive `null` as result.",
      "Is there any way to tell the two cases apart?",
      "The [`has`](https://stedolan.github.io/jq/manual/v1.6/#has(key)) built-in returns a boolean value representing whether its argument exists in its input as a key (or index, if the input is an array).",
      "$ echo '{\"foo\": null}' | jq 'has(\"foo\")'\ntrue",
      "$ echo '{\"foo\": null}' | jq 'has(\"bar\")'\nfalse"
    ],
    "utterance": "Determine if a key exists in an object, even if its value is null.",
    "expressions": [
      "has(\"foo\")",
      "has(\"bar\")"
    ],
    "data": [
      {
        "input": {
          "foo": null
        },
        "output": true
      },
      {
        "input": {
          "foo": null
        },
        "output": false
      }
    ],
    "identifier": 63374134
  },
  {
    "context": [
      "Question is how using **jq**'s filters and condition statement create a new file/array adding after the `\"Landline\": false` `\"Mobile\": false` for `John Doe`? So the resulting array should look like the following:",
      "[ { \"City\": \"San Francisco\", \"Person\": \"John Doe\", \"Landline\": false, \"Mobile\": false }, { \"City\": \"Los Angeles\", \"Person\": \"Steve Smith\", \"Landline\": false } ]",
      "So the algorithm should be following -  if in the `mobile.json` there is `\"Person\": \"John Doe\"` entry and in the same block there is `\"Mobile\": false` entry, then add `\"Mobile\": false` entry after `\"Landline\": false` for `\"Person\": \"John Doe\"` in `landline.json`.",
      "Here is a filter to get you started.  With the following in **merge.jq** and the other files you've specified",
      "jq -Ms -f merge.jq landline.json mobile.json",
      "produces",
      "[ { \"City\": \"San Francisco\", \"Person\": \"John Doe\", \"Landline\": false, \"Mobile\": false }, { \"City\": \"Los Angeles\", \"Person\": \"Steve Smith\", \"Landline\": false } ]",
      "For this type of problem, a \"dictionary lookup\" is easy to understand, and given jq's `INDEX` function, also easy to implement. Consider for example:",
      "jq -n '  def key: {City,Person}; (input | INDEX(.[]; key) | map_values( {Mobile} ) ) as $mobile | input | map( . + $mobile[key|tostring] )' mobile.json landline.json"
    ],
    "utterance": "Add Mobile: false to the entry in landline.json for Person: John Doe if that person with the same City exists in mobile.json with Mobile: false.",
    "expressions": [
      "def key: [.Person, .City] ; [ reduce .[][] as $e ({}; setpath($e|key; getpath($e|key) + $e)) | .[][] | select(.Landline != null) ]",
      "def key: {City,Person}; (input | INDEX(.[]; key) | map_values( {Mobile} ) ) as $mobile | input | map( . + $mobile[key|tostring] )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "City": "San Francisco",
              "Person": "John Doe",
              "Landline": false
            },
            {
              "City": "Los Angeles",
              "Person": "Steve Smith",
              "Landline": false
            }
          ],
          [
            {
              "City": "San Francisco",
              "Person": "John Doe",
              "Mobile": false
            },
            {
              "City": "Los Angeles",
              "Person": "Jenny Miller",
              "Mobile": false
            }
          ]
        ],
        "output": [
          {
            "City": "San Francisco",
            "Person": "John Doe",
            "Landline": false,
            "Mobile": false
          },
          {
            "City": "Los Angeles",
            "Person": "Steve Smith",
            "Landline": false
          }
        ]
      }
    ],
    "identifier": 63352438
  },
  {
    "context": [
      "I'm making a call to AWS to get the initial list and passing it into `jq` to be able to extract one property from each of the objects in the JSON list piping the output into `awk` to generate a new generate a new command to execute for each of the items in the first list.",
      "aws acm list-certificates |\njq '.CertificateSummaryList[].CertificateArn' |",
      "The command below is an example of a similar approach just short circuiting the first part and taking just one item from the list then doing the check to see if the length of one of the properties is greater than zero.",
      "jq '.Certificate | select( (.InUseBy | length) > 0) | .InUseBy, .Type'",
      "Sample `aws acm list-certificates` ...",
      "`jq -r '.CertificateSummaryList[].CertificateArn'`"
    ],
    "utterance": "Extract all CertificateArn values from the CertificateSummaryList array.",
    "expressions": [
      ".CertificateSummaryList[].CertificateArn",
      ".CertificateSummaryList[] | .CertificateArn",
      ".CertificateSummaryList[] | select(.CertificateArn != null) | .CertificateArn",
      ".CertificateSummaryList[] | .CertificateArn? // empty"
    ],
    "data": [
      {
        "input": {
          "CertificateSummaryList": [
            {
              "CertificateArn": "arn:aws:acm:us-east-1:123456789012:certificate/12345678-1234-1234-1234-123456789012",
              "DomainName": "www.example.com"
            },
            {
              "CertificateArn": "arn:aws:acm:us-east-1:493619779192:certificate/87654321-4321-4321-4321-210987654321",
              "DomainName": "www.example.net"
            }
          ]
        },
        "output": [
          "arn:aws:acm:us-east-1:123456789012:certificate/12345678-1234-1234-1234-123456789012",
          "arn:aws:acm:us-east-1:493619779192:certificate/87654321-4321-4321-4321-210987654321"
        ]
      }
    ],
    "identifier": 63369021
  },
  {
    "context": [
      "and want to get only device name (into json look like aaa1234a), `ip` and `otherInformation` with **jq**.",
      "i need a result:\n\"aaa1234a\": {\n            \"ip\": \"192.168.1.4\",\n            \"otherInformation\": \"blabla4\"\n            },\n\"aaa1235a\": {\n            \"ip\": \"192.168.1.5\",\n            \"otherInformation\": \"blabla5\"\n            },\n\"aaa1236a\": {\n            \"ip\": \"192.168.1.6\",\n            \"otherInformation\": \"blabla6\"\n            }",
      "When I execute the query \n\n```.data.devices | to_entries | map({key, value: {ip: .value.ip, otherInformation: .value.otherInformation}}) | from_entries```",
      "To select the keys matching the regex pattern \"^aaa.*a$\", you could write:\n```\n.devices | with_entries(select(.key|test(\"^aaa.*a$\")))\n```"
    ],
    "utterance": "Extract all devices whose keys match the pattern ^aaa.*a$, returning only the device key, ip, and otherInformation fields.",
    "expressions": [
      ".data.devices | to_entries | map({key, value: {ip: .value.ip, otherInformation: .value.otherInformation}}) | from_entries",
      ".data.devices | with_entries(select(.key|test(\"^aaa.*a$\"))) | to_entries | map({key, value: {ip: .value.ip, otherInformation: .value.otherInformation}}) | from_entries"
    ],
    "data": [
      {
        "input": {
          "error": 0,
          "descErr": "Ok",
          "seqNumber": 0,
          "data": {
            "events": [],
            "devices": {
              "aaa1234a": {
                "deviceType": "aaa",
                "ip": "192.168.1.4",
                "otherInformation": "blabla4"
              },
              "aaa1235a": {
                "deviceType": "aaa",
                "ip": "192.168.1.5",
                "otherInformation": "blabla5"
              },
              "aaa1236a": {
                "deviceType": "aaa",
                "ip": "192.168.1.6",
                "otherInformation": "blabla6"
              }
            }
          }
        },
        "output": {
          "aaa1234a": {
            "ip": "192.168.1.4",
            "otherInformation": "blabla4"
          },
          "aaa1235a": {
            "ip": "192.168.1.5",
            "otherInformation": "blabla5"
          },
          "aaa1236a": {
            "ip": "192.168.1.6",
            "otherInformation": "blabla6"
          }
        }
      }
    ],
    "identifier": 63374014
  },
  {
    "context": [
      "I would like output a csv file from this data that looks like this:",
      "\"1234\",\"332\",\"-79\", \"45\"",
      "\"1234\", \"33\", \"-77\", \"32\"",
      "Is there a way to access a value from somewhere else in the json data?",
      "You can use a variable to do so:\r\n\r\n    jq '.data.id as $id | .data.details[] | [$id, .vid, .long, .lat]' file.json",
      "Or without a variable:\r\n\r\n    jq -r '.data | [.id] + (.details[] | [.vid, .long, .lat]) | @csv' file.json",
      "If you really want all the values to be quoted, simply add `map(tostring)` to the pipeline before the final `@csv`."
    ],
    "utterance": "Output each entry in details as a CSV row, prepending the parent id to each row.",
    "expressions": [
      ".data.id as $id | .data.details[] | [$id, .vid, .long, .lat]",
      ".data | [.id] + (.details[] | [.vid, .long, .lat]) | @csv",
      ".data | [.id] + (.details[] | [.vid, .long, .lat] | map(tostring)) | @csv"
    ],
    "data": [
      {
        "input": {
          "data": {
            "id": 1234,
            "details": [
              {
                "vid": "332",
                "long": -79,
                "lat": 45
              },
              {
                "vid": "33",
                "long": -77,
                "lat": 32
              }
            ]
          }
        },
        "output": [
          "\"1234\",\"332\",\"-79\", \"45\"",
          "\"1234\", \"33\", \"-77\", \"32\""
        ]
      }
    ],
    "identifier": 63380882
  },
  {
    "context": [
      "but the nfs-0_tags line section also needs to be in name=value format. What I want to end up with is this\nnfs-0_create_option=\"Restore\"\nnfs-0_disk_iops_read_write=\"120\"\nnfs-0_disk_mbps_read_write=\"25\"\nnfs-0_tags={Monitor=\"No\", VaultBackup=\"2dc504bd\"}",
      "But I need the tags line in curly braces {} with the key unquoted and the value quoted. Like this\nnfs-0_tags={Monitor=\"No\", VaultBackup=\"2dc504bd\"}",
      "I still want the output to look like this \nnfs-0_create_option=\"Restore\"\nnfs-0_disk_iops_read_write=\"120\"\nnfs-0_disk_mbps_read_write=\"25\"\nnfs-0_tags={Monitor=\"No\", VaultBackup=\"2dc504bd\"}\nafter the jq runs",
      "def f:\n if .value|type==\"object\" then\n  \"nfs-0_(.key)={( [.value|to_entries|.[]|\"(.key)=\\\"(.value)\\\"\"]|join(\",\"))}\"\n else\n  \"nfs-0_(.key)=\\\"(.value)\\\"\"\n end;\n\nto_entries|.[]|f",
      "Here is a solution that allows arbitrarily deep nesting and illustrates the use of recursive inner functions:\ndef pairs:\n  def q:\n    if type == \"string\" then tojson\n    elif type == \"number\" then \"\\\"\\(.)\\\"\"\n    else . end;\n  def ip:\n    if type == \"object\"\n    then \"{\" + (to_entries | map(\"(.key)=\\(.value|ip)\") | join(\",\")) + \"}\"\n    else q end;\n  if type == \"object\"\n  then to_entries[] | (\"(.key)=\\(.value | ip)\")\n  else . end;\n\npairs"
    ],
    "utterance": "Convert an object with nested objects so each top-level key becomes a line of key=\"value\", and for nested objects, format them as key={nestedKey=\"nestedValue\", ...}, with specific prefix 'nfs-0_' applied to all top-level keys.",
    "expressions": [
      "def f:\n if .value|type==\"object\" then\n  \"nfs-0_\\(.key)={\\([.value|to_entries|.[]|\"\\(.key)=\\\"\\(.value)\\\"\" ]|join(\",\"))}\"\n else\n  \"nfs-0_\\(.key)=\\\"\\(.value)\\\"\"\n end;\nto_entries|.[]|f",
      "def pairs:\n  def q:\n    if type == \"string\" then tojson\n    elif type == \"number\" then \"\\\"\\(.)\\\"\"\n    else . end;\n  def ip:\n    if type == \"object\"\n    then \"{\" + (to_entries | map(\"\\(.key)=\\(.value|ip)\") | join(\",\")) + \"}\"\n    else q end;\n  if type == \"object\"\n  then to_entries[] | (\"nfs-0_\\(.key)=\\(.value | ip)\")\n  else . end;\npairs"
    ],
    "data": [
      {
        "input": {
          "create_option": "Restore",
          "disk_iops_read_write": 120,
          "disk_mbps_read_write": 25,
          "tags": {
            "Monitor": "No",
            "RSVaultBackup": "2dc504bd"
          }
        },
        "output": [
          "nfs-0_create_option=\"Restore\"",
          "nfs-0_disk_iops_read_write=\"120\"",
          "nfs-0_disk_mbps_read_write=\"25\"",
          "nfs-0_tags={Monitor=\"No\",RSVaultBackup=\"2dc504bd\"}"
        ]
      }
    ],
    "identifier": 63303863
  },
  {
    "context": [
      "I need to return a perfectly formatted (without nesting) array; i.e :\n\n    {\n      {\n        \"term\": \"alpha\"\n      },\n      {\n        \"term\": \"beta\"\n      },\n      {\n        \"term\": \"gamma\"\n      },\n    }",
      "I want to know which objects are returned from the API that are **NOT currently** a running tmux of same name.",
      "Then you could use an invocation of jq along the following lines:\n```\n< blacklist.txt jq --argjson curl \"$(curl https://myapi.call)\" -Rn '\n  [inputs] as $blacklist\n  | [ $curl\n      | .online_terms[]\n      | select( .term | IN($blacklist[]) | not) ]'\n```",
      "curl https://myapi.call | \n  jq --argjson blacklist \"$(jq -Rn '[inputs]' blacklist.txt)\" '\n    [.online_terms[]\n     | select( .term | IN($blacklist[]) | not)]'\n\n"
    ],
    "utterance": "Return all objects from the online_terms array whose term value does not appear in a blacklist of tmux session names.",
    "expressions": [
      "[inputs] as $blacklist | [ $curl | .online_terms[] | select( .term | IN($blacklist[]) | not) ]",
      "[.online_terms[] | select(.term | IN($blacklist[]) | not)]"
    ],
    "data": [
      {
        "input": {
          "online_terms": [
            {
              "term": "alpha"
            },
            {
              "term": "beta"
            },
            {
              "term": "gamma"
            }
          ],
          "total": 3
        },
        "output": [
          {
            "term": "beta"
          },
          {
            "term": "gamma"
          }
        ]
      }
    ],
    "identifier": 63385068
  },
  {
    "context": [
      "I have a aws cli bash loop generating multiple json lists, containing dictionaries.\r\nI can't get jq to merge the lists into one large list with all the dictionaries.",
      "Assuming you have jq 1.5, the solution posted here:\r\n\r\nhttps://stackoverflow.com/questions/51491317/jq-how-to-merge-multiple-objects-into-one\r\n\r\nprovides the basic technique of using `jq -n` with the `inputs` operator.",
      "cat FILE | jq -n '[inputs|.[]]'",
      "[inputs] glues the multiple results into a single list and the '.[]' strips the extra level of list that was added."
    ],
    "utterance": "Combine multiple lists of dictionaries into a single flat list containing all dictionaries across all lists.",
    "expressions": [
      "[inputs|.[]]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key1": "value1",
              "key2": "value2"
            },
            {
              "key1": "value3",
              "key2": "value4"
            }
          ],
          [
            {
              "key1": "value5",
              "key2": "value6"
            }
          ],
          [
            {
              "key1": "value7"
            }
          ]
        ],
        "output": [
          {
            "key1": "value1",
            "key2": "value2"
          },
          {
            "key1": "value3",
            "key2": "value4"
          },
          {
            "key1": "value5",
            "key2": "value6"
          },
          {
            "key1": "value7"
          }
        ]
      }
    ],
    "identifier": 63393366
  },
  {
    "context": [
      "If in case the line dosent contain the **mode** value then insert it as \"mode\": \"NULLABLE\" inbetween the type and name attributes.",
      "Below program produces the expected output by inserting `mode: \"NULLABLE\"` pair between `type` and `name` keys of each object that doesn't have a `mode` key.",
      "map(select(has(\"mode\") | not) |= {type, mode: \"NULLABLE\", name})"
    ],
    "utterance": "Add the key 'mode' with value 'NULLABLE' to each object if the key is missing.",
    "expressions": [
      "map(select(has(\"mode\") | not) |= {type, mode: \"NULLABLE\", name})"
    ],
    "data": [
      {
        "input": [
          {
            "type": "STRING",
            "name": "Article"
          },
          {
            "type": "STRING",
            "name": "Sellable_UOM"
          },
          {
            "type": "STRING",
            "name": "PriceFamilyCode"
          },
          {
            "type": "STRING",
            "name": "PriceFamilyDescription"
          },
          {
            "type": "STRING",
            "name": "SalesDistrict"
          },
          {
            "type": "DATE",
            "name": "FiscalWeekendDate"
          },
          {
            "type": "STRING",
            "mode": "REPEATED",
            "name": "export_sql"
          },
          {
            "type": "STRING",
            "mode": "REPEATED",
            "name": "post_sql"
          }
        ],
        "output": [
          {
            "type": "STRING",
            "mode": "NULLABLE",
            "name": "Article"
          },
          {
            "type": "STRING",
            "mode": "NULLABLE",
            "name": "Sellable_UOM"
          },
          {
            "type": "STRING",
            "mode": "NULLABLE",
            "name": "PriceFamilyCode"
          },
          {
            "type": "STRING",
            "mode": "NULLABLE",
            "name": "PriceFamilyDescription"
          },
          {
            "type": "STRING",
            "mode": "NULLABLE",
            "name": "SalesDistrict"
          },
          {
            "type": "DATE",
            "mode": "NULLABLE",
            "name": "FiscalWeekendDate"
          },
          {
            "type": "STRING",
            "mode": "REPEATED",
            "name": "export_sql"
          },
          {
            "type": "STRING",
            "mode": "REPEATED",
            "name": "post_sql"
          }
        ]
      }
    ],
    "identifier": 63407632
  },
  {
    "context": [
      "the '403add1f-25d9-4a24-99ff-12c5559fecfa' is reading from the id, and the 2 is the number of members.",
      "Expected output:",
      "403add1f-25d9-4a24-99ff-12c5559fecfa=2",
      "ranj-25d9-4a24-99ff-12c5559fecfa=1",
      "jq -r '.pools[] | \"\\(.id)=\\(.members|length)\"'"
    ],
    "utterance": "For each pool, print its id and the count of its members, formatted as id=count (e.g., 403add1f-25d9-4a24-99ff-12c5559fecfa=2).",
    "expressions": [
      ".pools[] | \"\u001b\\(.id)=\\(.members|length)\""
    ],
    "data": [
      {
        "input": {
          "pools": [
            {
              "id": "403add1f-25d9-4a24-99ff-12c5559fecfa",
              "members": [
                {
                  "id": "2b8e1155-aae0-4999-a038-ec900fd8e5b6"
                },
                {
                  "id": "3010bc81-e76d-462a-b4cc-2dc0888d65d2"
                }
              ]
            },
            {
              "id": "ranj-25d9-4a24-99ff-12c5559fecfa",
              "members": [
                {
                  "id": "ranj-aae0-4999-a038-ec900fd8e5b6"
                }
              ]
            }
          ],
          "pools_links": []
        },
        "output": [
          "403add1f-25d9-4a24-99ff-12c5559fecfa=2",
          "ranj-25d9-4a24-99ff-12c5559fecfa=1"
        ]
      }
    ],
    "identifier": 63408713
  },
  {
    "context": [
      "Say we have the following object in a json file:  \r\n> {\"a\": [1,2,3], \"b\": [4,5,6]}\r\n\r\nHow can I get the following output?:\r\n\r\n     \"a\"  \"b\"\r\n      1    4\r\n      2    5\r\n      3    6",
      "Here is a generic solution (notice there is no mention of \"a\" or \"b\") using `transpose`:\r\n```\r\n(keys_unsorted | map(tojson)),   # the header line\r\n ([.[]] | transpose[])\r\n| @tsv\r\n```\r\n### Invocation\r\n\r\njq -r -f program.jq data.json\r\n### Output\r\n```\n\"a\"\t\"b\"\n1\t4\n2\t5\n3\t6\n```"
    ],
    "utterance": "Display two arrays with the same keys side by side, with a header row of key names, and each subsequent row containing corresponding elements from each array.",
    "expressions": [
      "(keys_unsorted | map(tojson)), ([.[]] | transpose[]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "a": [
            1,
            2,
            3
          ],
          "b": [
            4,
            5,
            6
          ]
        },
        "output": [
          "\"a\"\t\"b\"",
          "1\t4",
          "2\t5",
          "3\t6"
        ]
      }
    ],
    "identifier": 63431239
  },
  {
    "context": [
      "The **time.total** value of \"null\" I'd like to change to 0, so I can perform math on it. (I intend to divide by 3600 to covert the value to hours, e.g 1.25)",
      "Instead of `.time.total`, you could write:",
      "    (.time.total // 0)"
    ],
    "utterance": "Replace null values in the time.total field with 0.",
    "expressions": [
      ".[] | .name, (.time.total // 0), .dueOn"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Task one",
            "time": {
              "total": 35160
            },
            "dueOn": "2020-08-14"
          },
          {
            "name": "Task two",
            "time": {
              "total": null
            },
            "dueOn": null
          },
          {
            "name": "Task three",
            "time": {
              "total": null
            },
            "dueOn": null
          },
          {
            "name": "Task 4",
            "time": {
              "total": 2280
            },
            "dueOn": null
          }
        ],
        "output": [
          "Task one",
          35160,
          "2020-08-14",
          "Task two",
          0,
          null,
          "Task three",
          0,
          null,
          "Task 4",
          2280,
          null
        ]
      }
    ],
    "identifier": 63420788
  },
  {
    "context": [
      "I can select the value of \"code\" where the \"system\" is \"target\", thus:",
      "{id: .id} + {\"code\": .coding[]? | select(.system==\"target\").code}",
      "But if the object whose \"system\" value is \"target\" does not exist in the array...",
      "I want the following result:\n\n    {\n        \"id\": 1,\n        \"code\": null\n    }",
      "my above jq produces an empty object. How can I achieve what I want?",
      "Instead, use the `first` built-in for alternating between the `code` value from the object where `system` is `target`, and `null`.",
      "{ id, code: first((.coding[]? | select(.system == \"target\") .code), null) }"
    ],
    "utterance": "For each object, include its id and the code value from the first array element where system is target, or null if such an element does not exist.",
    "expressions": [
      "{ id, code: first((.coding[]? | select(.system == \"target\") .code), null) }"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "coding": [
            {
              "code": 1234,
              "system": "target"
            },
            {
              "code": 5678,
              "system": "other"
            }
          ]
        },
        "output": {
          "id": 1,
          "code": 1234
        }
      },
      {
        "input": {
          "id": 1,
          "coding": [
            {
              "code": 5678,
              "system": "other"
            }
          ]
        },
        "output": {
          "id": 1,
          "code": null
        }
      }
    ],
    "identifier": 63412573
  },
  {
    "context": [
      "**What I need is to turn the parent key \"DBInstancePrefix\" dynamic based on a substring from \"DBInstanceIdentifier\" key**. So for the example names I wrote would be:",
      "> \"db1-name\" >>> \"db1\" \n> \"db2-name\" >>> \"db2\"\n\nSo, my desired output would be:\n```\n[\n  {\n    \"db1\": {\n      \"DBInstanceClass\": \"db.m5.xlarge\",\n      ...",
      "Your case demands the `DBInstanceIdentifier` to be split by `-` and using the first element in the resultant array. \n\nWith that and few other trivial modifications, you need\n\n    .DBInstances |\n    map\n    (\n      {\n        ( .DBInstanceIdentifier | split(\"-\")[0] ): { ... } }\n    )",
      "Based on [Inian][1] [answer][2], I did a small modification since my real *DBInstanceIdentifier* values have the following format:\n`<name>-db-<environment>` and I need *DBInstancePrefix* becomes `<name>-db`.\n\nSo, my final filter is:\n```\n.DBInstances |\nmap\n(      \n  {        \n    ( .DBInstanceIdentifier|split(\"-\")[0:2] | join(\"-\") ): { ... }     \n  } \n)\n```"
    ],
    "utterance": "Create objects where the key is the first part of DBInstanceIdentifier split by '-', and the value is selected details about the instance; example: for DBInstanceIdentifier 'db1-name', the key should be 'db1'.",
    "expressions": [
      ".DBInstances | map({ ( .DBInstanceIdentifier | split(\"-\")[0] ): { DBInstanceClass, DBInstanceIdentifier, DBName, DBParameterGroupName:.DBParameterGroups[].DBParameterGroupName, DBSubnetGroupName: .DBSubnetGroup.DBSubnetGroupName, KmsKeyId, OptionGroupName: .OptionGroupMemberships[].OptionGroupName, VpcSecurityGroupIds: [.VpcSecurityGroups[] | .VpcSecurityGroupId ] } })",
      ".DBInstances | map({ ( .DBInstanceIdentifier | split(\"-\")[0:2] | join(\"-\") ): { DBInstanceClass, DBInstanceIdentifier, DBName, DBParameterGroupName:.DBParameterGroups[].DBParameterGroupName, DBSubnetGroupName: .DBSubnetGroup.DBSubnetGroupName, KmsKeyId, OptionGroupName: .OptionGroupMemberships[].OptionGroupName, VpcSecurityGroupIds: [.VpcSecurityGroups[] | .VpcSecurityGroupId ] } })"
    ],
    "data": [
      {
        "input": {
          "DBInstances": [
            {
              "DBInstanceIdentifier": "db1-name",
              "DBInstanceClass": "db.m5.xlarge",
              "Engine": "oracle-ee",
              "DBInstanceStatus": "available",
              "MasterUsername": "user",
              "DBName": "RANDOM",
              "Endpoint": {
                "Address": "some-endpoint.rds.amazonaws.com",
                "Port": 5698,
                "HostedZoneId": "GHDSFHFSDHSDH"
              },
              "AllocatedStorage": 4000,
              "InstanceCreateTime": "2018-07-23T23:21:42.361000+00:00",
              "PreferredBackupWindow": "09:30-07:00",
              "BackupRetentionPeriod": 14,
              "DBSecurityGroups": [],
              "VpcSecurityGroups": [
                {
                  "VpcSecurityGroupId": "sg-xxxxxxxxxxxxxxxxx",
                  "Status": "active"
                },
                {
                  "VpcSecurityGroupId": "sg-xxxxxxxxxxxxxxxxx",
                  "Status": "active"
                }
              ],
              "DBParameterGroups": [
                {
                  "DBParameterGroupName": "DB1-parameter",
                  "ParameterApplyStatus": "in-sync"
                }
              ],
              "AvailabilityZone": "ZONE1",
              "DBSubnetGroup": {
                "DBSubnetGroupName": "dbsubnetgroup-1",
                "DBSubnetGroupDescription": "dbsubnetgroup-1",
                "VpcId": "vpc-xxxxxxxxxxxxxxxxx",
                "SubnetGroupStatus": "Complete",
                "Subnets": [
                  {
                    "SubnetIdentifier": "subnet-xxxxxxxxxxxxxxxxx",
                    "SubnetAvailabilityZone": {
                      "Name": "az1"
                    },
                    "SubnetStatus": "Active"
                  },
                  {
                    "SubnetIdentifier": "subnet-xxxxxxxxxxxxxxxxx",
                    "SubnetAvailabilityZone": {
                      "Name": "az2"
                    },
                    "SubnetStatus": "Active"
                  }
                ]
              },
              "PreferredMaintenanceWindow": "sat:07:00-sat:07:30",
              "PendingModifiedValues": {},
              "LatestRestorableTime": "2020-03-27T18:54:25+00:00",
              "MultiAZ": false,
              "EngineVersion": "X.X.X",
              "AutoMinorVersionUpgrade": false,
              "ReadReplicaDBInstanceIdentifiers": [],
              "LicenseModel": "bring-your-own-license",
              "Iops": 5000,
              "OptionGroupMemberships": [
                {
                  "OptionGroupName": "optiongroupName",
                  "Status": "in-sync"
                }
              ],
              "CharacterSetName": "WE8ISO8859P15",
              "PubliclyAccessible": false,
              "StorageType": "io1",
              "DbInstancePort": 0,
              "StorageEncrypted": true,
              "KmsKeyId": "someKey",
              "DbiResourceId": "db-xxxxxxxxxxxxxxxxxxxxxxxxx",
              "CACertificateIdentifier": "rds-ca-2019",
              "DomainMemberships": [],
              "CopyTagsToSnapshot": true,
              "MonitoringInterval": 0,
              "DBInstanceArn": "someARN",
              "IAMDatabaseAuthenticationEnabled": false,
              "PerformanceInsightsEnabled": false,
              "DeletionProtection": false,
              "AssociatedRoles": []
            },
            {
              "DBInstanceIdentifier": "db2-name",
              "DBInstanceClass": "db.m5.large",
              "Engine": "oracle-ee",
              "DBInstanceStatus": "available",
              "MasterUsername": "user2",
              "DBName": "XXXX",
              "Endpoint": {
                "Address": "endpoint2.rds.amazonaws.com",
                "Port": 8974,
                "HostedZoneId": "FASDFDS54FSA"
              },
              "AllocatedStorage": 100,
              "InstanceCreateTime": "2020-04-23T21:38:53.023000+00:00",
              "PreferredBackupWindow": "01:00-05:30",
              "BackupRetentionPeriod": 35,
              "DBSecurityGroups": [],
              "VpcSecurityGroups": [
                {
                  "VpcSecurityGroupId": "sg-xxxxxxxxxxxxxxxxx",
                  "Status": "active"
                }
              ],
              "DBParameterGroups": [
                {
                  "DBParameterGroupName": "default",
                  "ParameterApplyStatus": "in-sync"
                }
              ],
              "AvailabilityZone": "AZ-2",
              "DBSubnetGroup": {
                "DBSubnetGroupName": "subnet-group",
                "DBSubnetGroupDescription": "",
                "VpcId": "vpc-xxxxxxxxxxxxxxxxx",
                "SubnetGroupStatus": "Complete",
                "Subnets": [
                  {
                    "SubnetIdentifier": "subnet-xxxxxxxxxxxxxxxxx",
                    "SubnetAvailabilityZone": {
                      "Name": "AZ-1"
                    },
                    "SubnetStatus": "Active"
                  },
                  {
                    "SubnetIdentifier": "subnet-xxxxxxxxxxxxxxxxx",
                    "SubnetAvailabilityZone": {
                      "Name": "AZ-2"
                    },
                    "SubnetStatus": "Active"
                  },
                  {
                    "SubnetIdentifier": "subnet-xxxxxxxxxxxxxxxxx",
                    "SubnetAvailabilityZone": {
                      "Name": "AZ-3"
                    },
                    "SubnetStatus": "Active"
                  }
                ]
              },
              "PreferredMaintenanceWindow": "sun:08:39-sun:09:09",
              "PendingModifiedValues": {},
              "LatestRestorableTime": "2020-07-27T18:53:18+00:00",
              "MultiAZ": false,
              "EngineVersion": "X.X.X",
              "AutoMinorVersionUpgrade": false,
              "ReadReplicaDBInstanceIdentifiers": [],
              "LicenseModel": "bring-your-own-license",
              "Iops": 2000,
              "OptionGroupMemberships": [
                {
                  "OptionGroupName": "optiongroup-name",
                  "Status": "in-sync"
                }
              ],
              "CharacterSetName": "AL32UTF8",
              "PubliclyAccessible": false,
              "StorageType": "io1",
              "DbInstancePort": 0,
              "StorageEncrypted": true,
              "KmsKeyId": "someARN",
              "DbiResourceId": "db-xxxxxxxxxxxxxxxxx",
              "CACertificateIdentifier": "rds-ca-2019",
              "DomainMemberships": [],
              "CopyTagsToSnapshot": false,
              "MonitoringInterval": 0,
              "DBInstanceArn": "someARN",
              "IAMDatabaseAuthenticationEnabled": false,
              "PerformanceInsightsEnabled": false,
              "DeletionProtection": false,
              "AssociatedRoles": []
            }
          ]
        },
        "output": [
          {
            "db1": {
              "DBInstanceClass": "db.m5.xlarge",
              "DBInstanceIdentifier": "db1-name",
              "DBName": "RANDOM",
              "DBParameterGroupName": "DB1-parameter",
              "DBSubnetGroupName": "dbsubnetgroup-1",
              "KmsKeyId": "someKey",
              "OptionGroupName": "optiongroupName",
              "VpcSecurityGroupIds": [
                "sg-xxxxxxxxxxxxxxxxx",
                "sg-xxxxxxxxxxxxxxxxx"
              ]
            }
          },
          {
            "db2": {
              "DBInstanceClass": "db.m5.large",
              "DBInstanceIdentifier": "db2-name",
              "DBName": "XXXX",
              "DBParameterGroupName": "default",
              "DBSubnetGroupName": "subnet-group",
              "KmsKeyId": "someARN",
              "OptionGroupName": "optiongroup-name",
              "VpcSecurityGroupIds": [
                "sg-xxxxxxxxxxxxxxxxx"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 63136507
  },
  {
    "context": [
      "Example doesn't work with `.Value <=$v` and instead returns all .Values even greater than 10 and not as expected less than or equal to 10",
      "Does work if .Value is hardcoded in `select()` to 10 `.Value <=10` and filters output for .Value less than or equal to 10",
      "In both examples the variables for $h and $i passed to jq select do work, just not the variable for $v ?",
      "Found my answer in that --arg passed variables are strings and not interpreted as numbers ... so need to be converted",
      "jq -r --arg i $ip --arg host $h --arg v $value 'select(.Value <=($v | tonumber) and .ClientRequestHost == $host and .ClientIP == $i)' file.json",
      "Or use the command-line option `-\u2014argjson`"
    ],
    "utterance": "Filter data to include only entries where the Value field is less than or equal to a provided numeric threshold, and ClientRequestHost and ClientIP match specified values.",
    "expressions": [
      "select(.Value <= ($v | tonumber) and .ClientRequestHost == $host and .ClientIP == $i)",
      "select(.Value <= $v and .ClientRequestHost == $host and .ClientIP == $i)"
    ],
    "identifier": 63431948
  },
  {
    "context": [
      "In this example, I want to omit everything under `.hits.hits`, maybe replace it with an ellipsis (\u2026) or simply ignore it. A good alternative would be to render only the `id` value in the example.",
      "Update all members of `.hits.hits` to leave only the `id` field using the program below, I guess this is what you&#39;re looking for.",
      ".hits.hits[] |= {id}",
      "Here&#39;s a function that does so for any given level, $n:",
      "def maxdepth($n):\n  . as $in\n  | reduce paths as $p (null;\n       if ($p|length) > $n\n       then .\n       else ($in | getpath($p) ) as $v\n       | if ($p|length) == $n\n         then if (($v|type ==\"object\") and ($v|length>1))\n              then setpath($p; \"{...}\" )\n              elif (($v|type == \"array\") and ($v|length>1))\n              then setpath($p; \"[...]\" )\n              else setpath($p; $v) \n              end\n         else setpath($p; $v) \n         end\n       end) ;",
      "maxdepth(2)\nUsing your example, `maxdepth(2)` produces:\n{\n  \"paging\": {\n    \"next\": \"items?page=12\",\n    \"previous\": \"items?page=10\"\n  },\n  \"hits\": {\n    \"total\": 10200,\n    \"max_score\": 1,\n    \"hits\": \"[...]\"\n  },\n  \"took\": 11,\n  \"timed_out\": false\n}\n"
    ],
    "utterance": "Remove or replace all fields nested under .hits.hits, either by only keeping the id for each entry or replacing the entire array with an ellipsis (\"[\u2026]\").",
    "expressions": [
      ".hits.hits[] |= {id}",
      "def maxdepth($n):\n  . as $in\n  | reduce paths as $p (null;\n       if ($p|length) > $n\n       then .\n       else ($in | getpath($p) ) as $v\n       | if ($p|length) == $n\n         then if (($v|type ==\"object\") and ($v|length>1))\n              then setpath($p; \"{...}\" )\n              elif (($v|type == \"array\") and ($v|length>1))\n              then setpath($p; \"[...]\" )\n              else setpath($p; $v) \n              end\n         else setpath($p; $v) \n         end\n       end) ;\nmaxdepth(2)"
    ],
    "data": [
      {
        "input": {
          "paging": {
            "next": "items?page=12",
            "previous": "items?page=10"
          },
          "hits": {
            "total": 10200,
            "max_score": 1,
            "hits": [
              {
                "id": 1337,
                "really large struct 1": "with long and complexed nested values"
              },
              {
                "id": 1338,
                "really large struct 1": "with long and complexed nested values"
              }
            ]
          },
          "took": 11,
          "timed_out": false
        },
        "output": {
          "paging": {
            "next": "items?page=12",
            "previous": "items?page=10"
          },
          "hits": {
            "total": 10200,
            "max_score": 1,
            "hits": [
              {
                "id": 1337
              },
              {
                "id": 1338
              }
            ]
          },
          "took": 11,
          "timed_out": false
        }
      },
      {
        "input": {
          "paging": {
            "next": "items?page=12",
            "previous": "items?page=10"
          },
          "hits": {
            "total": 10200,
            "max_score": 1,
            "hits": [
              {
                "id": 1337,
                "really large struct 1": "with long and complexed nested values"
              },
              {
                "id": 1338,
                "really large struct 1": "with long and complexed nested values"
              }
            ]
          },
          "took": 11,
          "timed_out": false
        },
        "output": {
          "paging": {
            "next": "items?page=12",
            "previous": "items?page=10"
          },
          "hits": {
            "total": 10200,
            "max_score": 1,
            "hits": "[...]"
          },
          "took": 11,
          "timed_out": false
        }
      }
    ],
    "identifier": 63417006
  }
]