[
  {
    "context": [
      "Is there a way to just flatten all the json into a csv **keeping the keys as headers** - with the extra difficulty that **there is a list `natures_of_control` which has a varying number of entries** (for which i used the pad function to get a rectangular result).",
      "Here is an approach based on programmatically determining the headers.",
      "[allpaths(scalars)] as $p\n| ($p | map(abbreviate) | @csv),\n  ([getpath($p[])] | @csv)",
      "Here is a solution which handles arrays in the input JSON by converting them to \"colon-separated values\":",
      "The following uses `input` to read the first object, and `inputs` to read the rest, so it is essential to invoke jq with the -n command-line option:\n\n    input as $first\n    | ($first|paths) as $paths\n    | ($paths | headers),\n      ($first | row($paths)),\n      (inputs | row($paths))"
    ],
    "utterance": "Flatten each object so all nested keys appear as CSV headers, preserving all values\u2014including arrays (joined as colon-separated if needed) and null fields, and output the data in CSV format with headers.",
    "expressions": [
      "def atos: map(tostring) | join(\":\");\ndef allpaths:\n  def conditional_recurse(f): def r: ., (select(.!=null) | f | r); r;\n  path(conditional_recurse(.[]?)) | select(length > 0);\n\ndef allpaths(filter):\n  allpaths as $p | getpath($p) as $v | select($v | filter) | $p;\n\nwalk( if type == \"array\" then atos else . end )\n| [allpaths(scalars)] as $p\n| ($p | map(last) | @csv),\n  ([getpath($p[])] | @csv)",
      "def atos: map(tostring) | join(\":\");\ndef allpaths:\n  def conditional_recurse(f): def r: ., (select(.!=null) | f | r); r;\n  path(conditional_recurse(.[]?)) | select(length > 0);\n\ndef allpaths(filter):\n  allpaths as $p | getpath($p) as $v | select($v | filter) | $p;\n\ndef paths:\n  walk( if type == \"array\" then atos else . end )\n  | [allpaths(scalars)] ;\n\ndef headers:\n  map(last) | @csv ; \n\ndef row($paths):\n  walk( if type == \"array\" then atos else . end )\n  | [getpath($paths[])]\n  | @csv ;\n\ninput as $first\n| ($first|paths) as $paths\n| ($paths | headers),\n  ($first | row($paths)),\n  (inputs | row($paths))"
    ],
    "data": [
      {
        "input": {
          "company_number": "09626947",
          "data": {
            "address": {
              "address_line_1": "Troak Close",
              "country": "England",
              "locality": "Christchurch",
              "postal_code": "BH23 3SR",
              "premises": "9",
              "region": "Dorset"
            },
            "country_of_residence": "United Kingdom",
            "date_of_birth": {
              "month": 11,
              "year": 1979
            },
            "etag": "7123fb76e4ad7ee7542da210a368baa4c89d5a06",
            "kind": "individual-person-with-significant-control",
            "links": {
              "self": "/company/09626947/persons-with-significant-control/individual/FFeqke7T3LvGvX6xmuGqi5SJXAk"
            },
            "name": "Ms Angela Lynette Miller",
            "name_elements": {
              "forename": "Angela",
              "middle_name": "Lynette",
              "surname": "Miller",
              "title": "Ms"
            },
            "nationality": "British",
            "natures_of_control": [
              "significant-influence-or-control"
            ],
            "notified_on": "2016-06-06"
          }
        },
        "output": "\"company_number\",\"address_line_1\",\"country\",\"locality\",\"postal_code\",\"premises\",\"region\",\"country_of_residence\",\"month\",\"year\",\"etag\",\"kind\",\"self\",\"name\",\"forename\",\"middle_name\",\"surname\",\"title\",\"nationality\",\"natures_of_control\",\"notified_on\"\n\"09626947\",\"Troak Close\",\"England\",\"Christchurch\",\"BH23 3SR\",\"9\",\"Dorset\",\"United Kingdom\",11,1979,\"7123fb76e4ad7ee7542da210a368baa4c89d5a06\",\"individual-person-with-significant-control\",\"/company/09626947/persons-with-significant-control/individual/FFeqke7T3LvGvX6xmuGqi5SJXAk\",\"Ms Angela Lynette Miller\",\"Angela\",\"Lynette\",\"Miller\",\"Ms\",\"British\",\"significant-influence-or-control\",\"2016-06-06\""
      }
    ],
    "identifier": 55226242
  },
  {
    "context": [
      "Now I want to get the max createdAt of foo platform? how to implement it by using jq?",
      "$ jq 'map(select(.platform == \"foo\") .createdAt) | max' file",
      "map(select(.platform==\"foo\"))\n| max_by(.createdAt)\n| .createdAt",
      "max_by(.[] | select(.platform==\"foo\"); .createdAt)\n| .createdAt"
    ],
    "utterance": "Find the maximum createdAt value where platform equals \"foo\".",
    "expressions": [
      "map(select(.platform == \"foo\") .createdAt) | max",
      "map(select(.platform==\"foo\")) | max_by(.createdAt) | .createdAt",
      "max_by(.[] | select(.platform==\"foo\"); .createdAt) | .createdAt"
    ],
    "data": [
      {
        "input": [
          {
            "createdAt": 1548729542000,
            "platform": "foo"
          },
          {
            "createdAt": 1548759398000,
            "platform": "foo"
          },
          {
            "createdAt": 1548912360000,
            "platform": "foo"
          },
          {
            "createdAt": 1548904550000,
            "platform": "bar"
          }
        ],
        "output": 1548912360000
      }
    ],
    "identifier": 54489648
  },
  {
    "context": [
      "I would like to put a function definition in /usr/lib/jq/mytest.jq to be included in my jq script.",
      "I can't get this command to work:\r\n\r\n    jq -n 'include \"mytest\";'",
      "Adding -L /usr/lib/jq to the command works, or I can create a ~/.jq/mytest.jq and that works as well. However, I'd like to use the ~/.jq file for startup. How can I have a startup script *and* a include search path without specifying -L on the command line??",
      "Use the module metadata feature, e.g.:",
      "include \"mytest\" {\"search\": \"/usr/local/lib/jq\"};",
      "$ jq -n 'include \"mytest\" {\"search\": \"/usr/local/lib/jq\"}; go'",
      "\"hello\""
    ],
    "utterance": "Include a function from mytest.jq located in /usr/local/lib/jq without specifying the -L option on the command line, and call the go function it defines.",
    "expressions": [
      "include \"mytest\" {\"search\": \"/usr/local/lib/jq\"}; go"
    ],
    "data": [
      {
        "input": null,
        "output": "hello"
      }
    ],
    "identifier": 55199250
  },
  {
    "context": [
      "And I want \r\n\r\n    {\r\n        \"wanted\": {\r\n                   \"here\": \"result\"\r\n                  }             \r\n    }",
      "`jq '.large.wanted'` removes the key `wanted`, but im trying to keep it. How can I do this?",
      "In brief, since {wanted: .wanted} can be abbreviated to {wanted}:\r\n\r\n    .large | {wanted}"
    ],
    "utterance": "Extract the 'wanted' field from within 'large' and retain the key 'wanted' in the output.",
    "expressions": [
      ".large | {wanted}"
    ],
    "data": [
      {
        "input": {
          "large": {
            "key1": "one",
            "key2": "two",
            "key3": "three",
            "wanted": {
              "here": "result"
            }
          }
        },
        "output": {
          "wanted": {
            "here": "result"
          }
        }
      }
    ],
    "identifier": 54816639
  },
  {
    "context": [
      "I am trying to get the Input JSON given below in the Output Structure given, but i am getting the structure as List instead of Map.",
      "I tried using the JQ Query given below, however this is creating a LIST of orderId, but i need a map.",
      "Adding `add` to your jq:\r\n\r\n    { errorMessage,\r\n      errorCode,\r\n      orderId:\r\n        (.orderId\r\n         | map({ (.orderId) :\r\n                   { orderId,\r\n                     targetRequirements:\r\n                       (.targetRequirements\r\n                        | map({preferenceOrder,targetID }) ) } })\r\n         | add ) }"
    ],
    "utterance": "Transform the 'orderId' field so each order ID maps to an object containing 'orderId' and 'targetRequirements' (with only 'preferenceOrder' and 'targetID'), and preserve the top-level 'errorCode' and 'errorMessage' fields; the resulting structure must be a map, not a list.",
    "expressions": [
      "{ errorMessage, errorCode, orderId: (.orderId | map({ (.orderId): { orderId, targetRequirements: (.targetRequirements | map({preferenceOrder, targetID})) } }) | add) }"
    ],
    "data": [
      {
        "input": {
          "errorMessage": null,
          "errorCode": null,
          "state": "Complete",
          "status": "Completed",
          "createdDate": "234234234234",
          "createdTime": "332432423433",
          "orderId": {
            "Order394": {
              "orderId": "Order394",
              "targetRequirements": [
                {
                  "targetID": "1234",
                  "targetDate": "targetDate",
                  "preferenceOrder": 1,
                  "matchID": "502"
                },
                {
                  "targetID": "1235",
                  "targetDate": "targetDate",
                  "preferenceOrder": 1,
                  "matchID": "503"
                }
              ],
              "username": "Arun",
              "address": "6166192",
              "Title": "Kumar"
            },
            "Order395": {
              "orderId": "Order395",
              "targetRequirements": [
                {
                  "targetDate": "targetDate",
                  "targetID": "1234",
                  "preferenceOrder": 1,
                  "matchID": "502"
                }
              ],
              "username": "Arun",
              "address": "6166192",
              "Title": "Kumar"
            }
          }
        },
        "output": {
          "errorCode": null,
          "errorMessage": null,
          "orderId": {
            "Order394": {
              "orderId": "Order394",
              "targetRequirements": [
                {
                  "preferenceOrder": 1,
                  "targetID": "1234"
                },
                {
                  "preferenceOrder": 1,
                  "targetID": "1235"
                }
              ]
            },
            "Order395": {
              "orderId": "Order395",
              "targetRequirements": [
                {
                  "preferenceOrder": 1,
                  "targetID": "1234"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 55048439
  },
  {
    "context": [
      "I'm trying to convert 7z file content list to json and can't fix missing separator between output converted blocks.",
      "The expected result should be:",
      "{ \"date\": \"2018-06-23\", \"time\": \"14:02:16\", \"attr\": \".\", \"size\": \"4646\", \"path\": \"Installer\\\\\", \"name\": \"License\", \"extn\": \"txt\" },\n{ \"date\": \"2018-06-23\", \"time\": \"14:02:16\", \"attr\": \".\", \"size\": \"138892\", \"path\": \"Installer\\\\\", \"name\": \"Setup\", \"extn\": \"exe\" }",
      "And I only got :",
      "{ \"date\": \"2018-06-23\", \"time\": \"14:02:16\", \"attr\": \".\", \"size\": \"4646\", \"path\": \"Installer\\\\\", \"name\": \"License\", \"extn\": \"txt\" }\n{ \"date\": \"2018-06-23\", \"time\": \"14:02:16\", \"attr\": \".\", \"size\": \"138892\", \"path\": \"Installer\\\\\", \"name\": \"Setup\", \"extn\": \"exe\" }",
      "without the comma separator between blocks.",
      "Your def for `parse_line` produces a stream of JSON entities, whereas you evidently want a JSON array.  Using your regex, you could write:",
      "[inputs | parse_line];",
      "A simpler solution\n\ndef parse_line:\n  capture(\"(?<date>\\\\d+-\\\\d+-\\\\d+) \" \n  + \"(?<time>\\\\d+:\\\\d+:\\\\d+) \" \n  + \"(?<attr>.)[^ ]* +\" \n  + \"(?<size>\\\\d+) +\\\\d+ +\"\n  + \"(?<path>.*\\\\\\\\)\"\n  + \"(?<name>[^\\\\\\\\]*)\\\\.\"\n  + \"(?<extn>.*)\");",
      "[inputs | parse_line]"
    ],
    "utterance": "Produce an array where each element represents a parsed line from the 7z file list, extracting fields such as date, time, attr, size, path, name, and extn, instead of outputting separate JSON objects without separators.",
    "expressions": [
      "[inputs | parse_line]",
      "[inputs | capture(\"(?<date>\\d+-\\d+-\\d+) \" + \"(?<time>\\d+:\\d+:\\d+) \" + \"(?<attr>.)[^ ]* +\" + \"(?<size>\\d+) +\\d+ +\" + \"(?<path>.*\\\\\\\\)\" + \"(?<name>[^\\\\\\\\]*)\\\\.\" + \"(?<extn>.*)\")]"
    ],
    "data": [
      {
        "input": "   Date      Time    Attr         Size   Compressed  Name\n------------------- ----- ------------ ------------  ------------------------\n2018-06-23 14:02:16 D....            0            0  Installer\n2018-06-23 14:02:16 .....         3381         1157  Installer\\Readme\n2018-06-23 14:02:16 .....         4646         1157  Installer\\License.txt\n2018-06-23 14:02:16 .....       138892       136152  Installer\\Setup.exe",
        "output": [
          {
            "date": "2018-06-23",
            "time": "14:02:16",
            "attr": ".",
            "size": "4646",
            "path": "Installer\\",
            "name": "License",
            "extn": "txt"
          },
          {
            "date": "2018-06-23",
            "time": "14:02:16",
            "attr": ".",
            "size": "138892",
            "path": "Installer\\",
            "name": "Setup",
            "extn": "exe"
          }
        ]
      }
    ],
    "identifier": 54572477
  },
  {
    "context": [
      "How can I merge the data in `stubs[]` matched by `port` property.",
      "Using the following command:",
      "jq -s '\n    def merge:\n     {\"protocol\": .[0].protocol,\n      \"port\": .[0].port,\n      \"name\": .[0].name,\n      \"stubs\": (reduce .[].stubs as $item ([]; . + $item) | unique)};\n    [[.[].imposters[]] | group_by(.port) | .[] | merge] |\n    {\"imposters\": .}' a.json",
      "This type of output can be generated:",
      "{\n      \"imposters\": [\n        {\n          \"protocol\": \"http\",\n          \"port\": 9000,\n          \"name\": \"sanc\",\n          \"stubs\": []\n        },\n        {\n          \"protocol\": \"http\",\n          \"port\": 9001,\n          \"name\": \"sanp\",\n          \"stubs\": [ ... ]\n        }\n      ]\n    }"
    ],
    "utterance": "Merge arrays of objects under 'stubs' for items sharing the same 'port' value, combining their stubs into a single array.",
    "expressions": [
      "jq -s '\ndef merge:\n {\"protocol\": .[0].protocol,\n  \"port\": .[0].port,\n  \"name\": .[0].name,\n  \"stubs\": (reduce .[].stubs as $item ([]; . + $item) | unique)};\n[[.[].imposters[]] | group_by(.port) | .[] | merge] |\n{\"imposters\": .}'"
    ],
    "data": [
      {
        "input": [
          {
            "imposters": [
              {
                "protocol": "http",
                "port": 9000,
                "name": "sanc",
                "stubs": []
              },
              {
                "protocol": "http",
                "port": 9001,
                "name": "sanp",
                "stubs": [
                  {
                    "predicates": [
                      {
                        "deepEquals": {
                          "path": "/user/access/resources"
                        }
                      }
                    ],
                    "responses": [
                      {
                        "is": {
                          "statusCode": 200,
                          "body": "H4sIAAAAAAAAA4yRQYvCMBCF="
                        }
                      }
                    ]
                  },
                  {
                    "predicates": [
                      {
                        "deepEquals": {
                          "path": "/user/access/pilot"
                        }
                      }
                    ],
                    "responses": [
                      {
                        "is": {
                          "statusCode": 200,
                          "body": "H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA=="
                        }
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "imposters": [
              {
                "protocol": "http",
                "port": 9000,
                "name": "sanc",
                "stubs": []
              },
              {
                "protocol": "http",
                "port": 9001,
                "name": "sanp",
                "stubs": [
                  {
                    "predicates": [
                      {
                        "deepEquals": {
                          "path": "/pay/resources"
                        }
                      }
                    ],
                    "responses": [
                      {
                        "is": {
                          "statusCode": 200,
                          "body": "H4sIAAAAAAAAA4yRQYvCMBCF="
                        }
                      }
                    ]
                  },
                  {
                    "predicates": [
                      {
                        "deepEquals": {
                          "path": "/pay/5"
                        }
                      }
                    ],
                    "responses": [
                      {
                        "is": {
                          "statusCode": 200,
                          "body": "H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA=="
                        }
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": {
          "imposters": [
            {
              "protocol": "http",
              "port": 9000,
              "name": "sanc",
              "stubs": []
            },
            {
              "protocol": "http",
              "port": 9001,
              "name": "sanp",
              "stubs": [
                {
                  "predicates": [
                    {
                      "deepEquals": {
                        "path": "/pay/5"
                      }
                    }
                  ],
                  "responses": [
                    {
                      "is": {
                        "statusCode": 200,
                        "body": "H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA=="
                      }
                    }
                  ]
                },
                {
                  "predicates": [
                    {
                      "deepEquals": {
                        "path": "/pay/resources"
                      }
                    }
                  ],
                  "responses": [
                    {
                      "is": {
                        "statusCode": 200,
                        "body": "H4sIAAAAAAAAA4yRQYvCMBCF="
                      }
                    }
                  ]
                },
                {
                  "predicates": [
                    {
                      "deepEquals": {
                        "path": "/user/access/pilot"
                      }
                    }
                  ],
                  "responses": [
                    {
                      "is": {
                        "statusCode": 200,
                        "body": "H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA=="
                      }
                    }
                  ]
                },
                {
                  "predicates": [
                    {
                      "deepEquals": {
                        "path": "/user/access/resources"
                      }
                    }
                  ],
                  "responses": [
                    {
                      "is": {
                        "statusCode": 200,
                        "body": "H4sIAAAAAAAAA4yRQYvCMBCF="
                      }
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 55052429
  },
  {
    "context": [
      "I have a JSON file that I want to process with JQ. It has an array of objects inside another object, with a key that I want to use to populate a new array.",
      "I'd like to use JQ to get a new array based on the elements, ignoring some elements and handling the missing ones. e.g.",
      "[\n  \"The 1st word is One\",\n  \"The 2nd word is Two\",\n  \"Wot no number 3?\",\n  \"Wot no number 4?\",\n  \"The 5th word is Five\"\n]",
      "jq 'def print(o): \"The \\(o.ordinal) word is \\(o.word)\";\n    .numbers | (reduce map(select(.numeral))[] as $o ({}; .[\"\\($o.numeral)\"] = $o)) as $o\n    | [range(0; ($o | [keys[] | tonumber] | max)) \n       | \"\\(.+1)\" as $i\n       | if ($o[$i]) then print($o[$i]) else \"Wot no number \\($i)?\" end\n    ]' input.json",
      "jq  '[ \n       range(1; ( .numbers | max_by(.numeral)|.numeral ) +1 ) as $range_do_diplay  | \n       .numbers as $thedata | $range_do_diplay |\n       . as $i | \n            if ([$thedata[]|contains( { numeral: $i })]|any ) \n            then \n               ($thedata|map(select( .numeral == $i )))|.[0]| \"The \\(.ordinal) word is \\(.word) \" \n            else \n               \"Wot no number \\($i)?\" \n            end  \n     ] ' numbers.json"
    ],
    "utterance": "Produce an array of strings describing the word for numerals 1 to 5, filling in missing numerals with 'Wot no number X?'.",
    "expressions": [
      "def print(o): \"The \\(o.ordinal) word is \\(o.word)\";\n    .numbers | (reduce map(select(.numeral))[] as $o ({}; .[\"\\($o.numeral)\"] = $o)) as $o\n    | [range(0; ($o | [keys[] | tonumber] | max)) \n       | \"\\(.+1)\" as $i\n       | if ($o[$i]) then print($o[$i]) else \"Wot no number \\($i)?\" end\n    ]",
      "[ range(1; ( .numbers | max_by(.numeral)|.numeral ) +1 ) as $range_do_diplay  | .numbers as $thedata | $range_do_diplay | . as $i | if ([$thedata[]|contains( { numeral: $i })]|any ) then ($thedata|map(select( .numeral == $i )))|.[0]| \"The \\(.ordinal) word is \\(.word) \" else \"Wot no number \\($i)?\" end ]"
    ],
    "data": [
      {
        "input": {
          "numbers": [
            {
              "numeral": 1,
              "ordinal": "1st",
              "word": "One"
            },
            {
              "numeral": 2,
              "ordinal": "2nd",
              "word": "Two"
            },
            {
              "numeral": 5,
              "ordinal": "5th",
              "word": "Five"
            },
            {
              "some-other-fluff-i-want-to-ignore": true
            }
          ]
        },
        "output": [
          "The 1st word is One",
          "The 2nd word is Two",
          "Wot no number 3?",
          "Wot no number 4?",
          "The 5th word is Five"
        ]
      }
    ],
    "identifier": 55198806
  },
  {
    "context": [
      "With the query i have, i am getting **state : null** for the entries which has  empty or null values. I want to hide the field itself in these cases.",
      ".amazon | { userType: .userType, userName: .user, itemCatalog: (.items | map({ itemId: .id, name, state} )) }| del(.itemCatalog[].state |select(. == null))"
    ],
    "utterance": "Transform the object's items so that fields with null values, such as state, are omitted from the output objects.",
    "expressions": [
      ".amazon | { userType: .userType, userName: .user, itemCatalog: (.items | map({ itemId: .id, name, state} )) }| del(.itemCatalog[].state |select(. == null))"
    ],
    "data": [
      {
        "input": {
          "amazon": {
            "activeitem": 2,
            "createdDate": "2019-01-15T17:36:31.588Z",
            "lastModifiedDate": "2019-01-15T17:36:31.588Z",
            "user": "net",
            "userType": "new",
            "items": [
              {
                "id": 1,
                "name": "harry potter",
                "state": "sold",
                "type": {
                  "branded": false,
                  "description": "artwork",
                  "contentLevel": "season"
                }
              },
              {
                "id": 2,
                "name": "adidas shoes",
                "state": null,
                "type": {
                  "branded": false,
                  "description": "Spprts",
                  "contentLevel": "season"
                }
              },
              {
                "id": 3,
                "name": "watch",
                "type": {
                  "branded": false,
                  "description": "walking",
                  "contentLevel": "special"
                }
              },
              {
                "id": 4,
                "name": "adidas shoes",
                "state": "in inventory",
                "type": {
                  "branded": false,
                  "description": "running",
                  "contentLevel": "winter"
                }
              }
            ],
            "product": {
              "id": 4,
              "name": "adidas shoes",
              "source": "dealer",
              "destination": "resident"
            }
          }
        },
        "output": {
          "userType": "new",
          "userName": "net",
          "itemCatalog": [
            {
              "itemId": 1,
              "name": "harry potter",
              "state": "sold"
            },
            {
              "itemId": 2,
              "name": "adidas shoes"
            },
            {
              "itemId": 3,
              "name": "watch"
            },
            {
              "itemId": 4,
              "name": "adidas shoes",
              "state": "in inventory"
            }
          ]
        }
      }
    ],
    "identifier": 54814990
  },
  {
    "context": [
      "Store a specified value, the last value of `token`, as a parameter. In this example that value would be `96f601b5769bacf7208b1a9c8c390278` and stored as `page_parameter`",
      "Store another specified value, the value associated with `total_items` at the top. In this examople, that value is `2371` and stored as `items_parameter`",
      "page_parameter=`cat raw.json | jq -c '.items | last | .token' | tr -d '\"'`",
      "items_parameter=`cat raw.json | jq -c '.total_items'`"
    ],
    "utterance": "Extract the last token value from the items array and the total_items value from the root object",
    "expressions": [
      ".items | last | .token",
      ".total_items"
    ],
    "data": [
      {
        "input": {
          "total_items": 2371,
          "page_count": 3,
          "items": [
            {
              "landing_id": "503a654cfaf5614b2069de304dbdb3c9",
              "token": "503a654cfaf5614b2069de304dbdb3c9",
              "response_id": "503a654cfaf5614b2069de304dbdb3c9",
              "landed_at": "2019-03-07T18:35:06Z",
              "submitted_at": "2019-03-07T18:36:17Z",
              "metadata": {
                "user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0.2 Safari/605.1.15",
                "platform": "other",
                "network_id": "321c8d9867",
                "browser": "default"
              },
              "answers": [
                {
                  "field": {
                    "id": "uqZV4j2RSapJ",
                    "type": "opinion_scale",
                    "ref": "bed55d05-b5e2-46dd-af91-337519830e3e"
                  },
                  "type": "number",
                  "number": 5
                }
              ]
            },
            {
              "landing_id": "b9d50e6734d30753de42b78a2ad5d741",
              "token": "b9d50e6734d30753de42b78a2ad5d741",
              "response_id": "b9d50e6734d30753de42b78a2ad5d741",
              "landed_at": "2019-03-07T18:12:29Z",
              "submitted_at": "2019-03-07T18:13:54Z",
              "metadata": {
                "user_agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 12_1_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1",
                "platform": "mobile",
                "network_id": "3a74e2b874",
                "browser": "touch"
              },
              "answers": [
                {
                  "field": {
                    "id": "uqZV4j2RSapJ",
                    "type": "opinion_scale",
                    "ref": "bed55d05-b5e2-46dd-af91-337519830e3e"
                  },
                  "type": "number",
                  "number": 1
                },
                {
                  "field": {
                    "id": "v8nQgm61VdLp",
                    "type": "dropdown",
                    "ref": "d20b5f19-dc7c-4497-b798-239924054367"
                  },
                  "type": "text",
                  "text": "Inconsistent information"
                }
              ]
            },
            {
              "landing_id": "96f601b5769bacf7208b1a9c8c390278",
              "token": "96f601b5769bacf7208b1a9c8c390278",
              "response_id": "96f601b5769bacf7208b1a9c8c390278",
              "landed_at": "2019-03-07T18:09:08Z",
              "submitted_at": "2019-03-07T18:09:40Z",
              "metadata": {
                "user_agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 12_1_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1",
                "platform": "mobile",
                "network_id": "1c59eb873c",
                "browser": "touch"
              },
              "answers": [
                {
                  "field": {
                    "id": "uqZV4j2RSapJ",
                    "type": "opinion_scale",
                    "ref": "bed55d05-b5e2-46dd-af91-337519830e3e"
                  },
                  "type": "number",
                  "number": 5
                },
                {
                  "field": {
                    "id": "llTPythU272I",
                    "type": "multiple_choice",
                    "ref": "bf54c521-3749-4c80-93bf-bb5448d03b34"
                  },
                  "type": "choices",
                  "choices": {
                    "labels": [
                      "Travis"
                    ]
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "token": "96f601b5769bacf7208b1a9c8c390278",
          "total_items": 2371
        }
      }
    ],
    "identifier": 55051099
  },
  {
    "context": [
      "How may I combine the two lists into a single list where each item is an object with the non-`id` properties for the given `id` are collected into a single object?",
      "jq '.listA+.listB | group_by(.id) | map(add)' test.json",
      "jq 'flatten | group_by(.id) | map(add)' test.json",
      "INDEX(.listA[]; .id) as $one\n| INDEX(.listB[]; .id) as $two\n| reduce ($one|keys_unsorted[]) as $k ($two; .[$k] += $one[$k])\n| {listC: [.[]] }"
    ],
    "utterance": "Combine two arrays of objects into a single array, merging objects that share the same id, including all non-id properties from both arrays.",
    "expressions": [
      ".listA + .listB | group_by(.id) | map(add)",
      "flatten | group_by(.id) | map(add)",
      "INDEX(.listA[]; .id) as $one | INDEX(.listB[]; .id) as $two | reduce ($one|keys_unsorted[]) as $k ($two; .[$k] += $one[$k]) | {listC: [.[]] }"
    ],
    "data": [
      {
        "input": {
          "listA": [
            {
              "id": "12345",
              "code": "001"
            },
            {
              "id": "12346",
              "code": "002"
            }
          ],
          "listB": [
            {
              "id": "12345",
              "prop": "AABBCC"
            }
          ]
        },
        "output": [
          {
            "id": "12345",
            "code": "001",
            "prop": "AABBCC"
          },
          {
            "id": "12346",
            "code": "002"
          }
        ]
      }
    ],
    "identifier": 54956517
  },
  {
    "context": [
      "Assuming all embedded JSON is a minified dictionary (as is the case with my Terraform output, AWS cli output, and AWS logs) this one `jq` script works wonders.",
      "jq 'walk(if type == \"string\" and .[0:2] == \"{\\\"\" then .=(.|fromjson) else . end)'",
      "Running `fromjson` on all strings could be done, e.g. using `walk` and `?`:",
      "walk(if type == \"string\" then fromjson? // . else . end)",
      "Leaving numeric strings alone",
      "walk(if type == \"string\"\n         then if tonumber? // false then . \n              else fromjson? // . end\n         else . end)"
    ],
    "utterance": "Replace any string values in an object that look like serialized objects with their parsed form, recursively for all such structures.",
    "expressions": [
      "walk(if type == \"string\" and .[0:2] == \"{\\\"\" then .=(.|fromjson) else . end)",
      "walk(if type == \"string\" then fromjson? // . else . end)",
      "walk(if type == \"string\" then if tonumber? // false then . else fromjson? // . end else . end)"
    ],
    "data": [
      {
        "input": {
          "Records": [
            {
              "EventVersion": "1.0",
              "EventSubscriptionArn": "arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6",
              "EventSource": "aws:sns",
              "Sns": {
                "SignatureVersion": "1",
                "Timestamp": "2019-02-06T15:50:30.028Z",
                "Signature": "GN3712/aWjVLftSzdOcW5Zm32/uvfZKrCcvTmz6Obv/AXbz1xc22sTMYt2vFja7coHGhhO5bG6dz/IbJSx/Zm0U/dVVefWKukFl1umP3av+1JoUbbi+4uHai3k3AwQa3wR4HWjrKKmMt+Tkt/gm7jvhcuojtx+n5oc4S6bMsVq5OmSfAWd2Xd1urTm2zeGCL59nbfhZv+xB4db3dk62FtxVKtFXtvO2pH27+E3vXUvgu2k1c2Kd/Vt/vbYCAA==",
                "SigningCertUrl": "https://sns.us-east-1.amazonaws.com/SimpleNotificationService-a70df027-2c7f-492a-840a-633d44fd71a6.pem",
                "MessageId": "a8df3067-c347-55ce-b869-64b2c7c1d0a3",
                "Message": "{\"AlarmName\":\"unauthorized_api_calls_Count-alarm\",\"AlarmDescription\":\"This metric monitors unauthorized API calls\",\"AWSAccountId\":\"123456789012\",\"NewStateValue\":\"ALARM\",\"NewStateReason\":\"Threshold Crossed: 1 datapoint [5.0 (06/02/19 15:45:00)] was greater than or equal to the threshold (1.0).\",\"StateChangeTime\":\"2019-02-06T15:50:30.023+0000\",\"Region\":\"US East (N. Virginia)\",\"OldStateValue\":\"INSUFFICIENT_DATA\",\"Trigger\":{\"MetricName\":\"unauthorized_api_calls\",\"Namespace\":\"security_rules\",\"StatisticType\":\"Statistic\",\"Statistic\":\"SUM\",\"Unit\":null,\"Dimensions\":[],\"Period\":300,\"EvaluationPeriods\":1,\"ComparisonOperator\":\"GreaterThanOrEqualToThreshold\",\"Threshold\":1.0,\"TreatMissingData\":\"\",\"EvaluateLowSampleCountPercentile\":\"\"}}",
                "MessageAttributes": {},
                "Type": "Notification",
                "UnsubscribeUrl": "https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6",
                "TopicArn": "arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services",
                "Subject": "ALARM: \"unauthorized_api_calls_Count-alarm\" in US East (N. Virginia)"
              }
            }
          ]
        },
        "output": {
          "Records": [
            {
              "EventVersion": "1.0",
              "EventSubscriptionArn": "arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6",
              "EventSource": "aws:sns",
              "Sns": {
                "SignatureVersion": "1",
                "Timestamp": "2019-02-06T15:50:30.028Z",
                "Signature": "GN3712/aWjVLftSzdOcW5Zm32/uvfZKrCcvTmz6Obv/AXbz1xc22sTMYt2vFja7coHGhhO5bG6dz/IbJSx/Zm0U/dVVefWKukFl1umP3av+1JoUbbi+4uHai3k3AwQa3wR4HWjrKKmMt+Tkt/gm7jvhcuojtx+n5oc4S6bMsVq5OmSfAWd2Xd1urTm2zeGCL59nbfhZv+xB4db3dk62FtxVKtFXtvO2pH27+E3vXUvgu2k1c2Kd/Vt/vbYCAA==",
                "SigningCertUrl": "https://sns.us-east-1.amazonaws.com/SimpleNotificationService-a70df027-2c7f-492a-840a-633d44fd71a6.pem",
                "MessageId": "a8df3067-c347-55ce-b869-64b2c7c1d0a3",
                "Message": {
                  "AlarmName": "unauthorized_api_calls_Count-alarm",
                  "AlarmDescription": "This metric monitors unauthorized API calls",
                  "AWSAccountId": "123456789012",
                  "NewStateValue": "ALARM",
                  "NewStateReason": "Threshold Crossed: 1 datapoint [5.0 (06/02/19 15:45:00)] was greater than or equal to the threshold (1.0).",
                  "StateChangeTime": "2019-02-06T15:50:30.023+0000",
                  "Region": "US East (N. Virginia)",
                  "OldStateValue": "INSUFFICIENT_DATA",
                  "Trigger": {
                    "MetricName": "unauthorized_api_calls",
                    "Namespace": "security_rules",
                    "StatisticType": "Statistic",
                    "Statistic": "SUM",
                    "Unit": null,
                    "Dimensions": [],
                    "Period": 300,
                    "EvaluationPeriods": 1,
                    "ComparisonOperator": "GreaterThanOrEqualToThreshold",
                    "Threshold": 1,
                    "TreatMissingData": "",
                    "EvaluateLowSampleCountPercentile": ""
                  }
                },
                "MessageAttributes": {},
                "Type": "Notification",
                "UnsubscribeUrl": "https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6",
                "TopicArn": "arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services",
                "Subject": "ALARM: \"unauthorized_api_calls_Count-alarm\" in US East (N. Virginia)"
              }
            }
          ]
        }
      }
    ],
    "identifier": 54562183
  },
  {
    "context": [
      "I am trying to put the content data into one **csv** file, Temperature data into second **csv** file, certifications into third, formats and inner details data in other separate file.",
      "jq -r '.[]|[.Title,.brand,.size,.date]|@csv' $jsonfile > sample.csv.",
      "Use map:  \n\n`$jq -r '.[] | map(.Title), map(.brand), map(.size), map(.date) | @csv' yourfile.json > sample.csv`",
      "for field in Temperature certifications ; do\n    echo $field ::\n    jq --arg field \"$field\" -r '\n      .content[].details | .[$field][]\n      | [.value, .characteristics] | @csv' input.json > output.$field.csv\n    done",
      "jq --arg field \"$field\" -r '.content[]\n      | [.Title, .brand] as $columns\n      | .details | .[$field][]\n      | ($columns + [.value, .characteristics]) | @csv\n    ' so-multiple-csv-files.json > tmp.output.$field.csv"
    ],
    "utterance": "Extract Temperature and certifications arrays from each entry inside content, and output their value and characteristics fields as CSV rows, optionally including Title and brand from the parent object.",
    "expressions": [
      ".content[].details.Temperature[] | [.value, .chracterstics] | @csv",
      ".content[].details.certifications[] | [.value, .chracterstics] | @csv",
      ".content[] | [.Title, .brand] as $columns | .details.Temperature[] | ($columns + [.value, .chracterstics]) | @csv",
      ".content[] | [.Title, .brand] as $columns | .details.certifications[] | ($columns + [.value, .chracterstics]) | @csv"
    ],
    "data": [
      {
        "input": {
          "content": [
            {
              "Title": "abc",
              "brand": "xyz",
              "size": "5 g",
              "date": "2019-01-01",
              "details": {
                "Temperature": [
                  {
                    "value": "90",
                    "chracterstics": "Normal"
                  },
                  {
                    "value": "100",
                    "chracterstics": "high"
                  },
                  {
                    "value": "80",
                    "chracterstics": "low"
                  }
                ],
                "certifications": [
                  {
                    "value": "based",
                    "chracterstics": "pass"
                  },
                  {
                    "value": "50",
                    "chracterstics": "failed"
                  }
                ]
              },
              "formats": {
                "city": "NYC",
                "id": "007",
                "manufacture": ""
              },
              "innerDetails": [
                {
                  "contains": "abc",
                  "panel": "xyz",
                  "values": [
                    {
                      "name": "abc",
                      "value": "10"
                    },
                    {
                      "name": "xyz",
                      "value": "20"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "\"90\",\"Normal\"",
          "\"100\",\"high\"",
          "\"80\",\"low\""
        ]
      },
      {
        "input": {
          "content": [
            {
              "Title": "abc",
              "brand": "xyz",
              "size": "5 g",
              "date": "2019-01-01",
              "details": {
                "Temperature": [
                  {
                    "value": "90",
                    "chracterstics": "Normal"
                  },
                  {
                    "value": "100",
                    "chracterstics": "high"
                  },
                  {
                    "value": "80",
                    "chracterstics": "low"
                  }
                ],
                "certifications": [
                  {
                    "value": "based",
                    "chracterstics": "pass"
                  },
                  {
                    "value": "50",
                    "chracterstics": "failed"
                  }
                ]
              },
              "formats": {
                "city": "NYC",
                "id": "007",
                "manufacture": ""
              },
              "innerDetails": [
                {
                  "contains": "abc",
                  "panel": "xyz",
                  "values": [
                    {
                      "name": "abc",
                      "value": "10"
                    },
                    {
                      "name": "xyz",
                      "value": "20"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "\"based\",\"pass\"",
          "\"50\",\"failed\""
        ]
      }
    ],
    "identifier": 55194124
  },
  {
    "context": [
      "I have the following JSON where I want to change the \"tag\" of the \"image\" strings.",
      "It should become:",
      "{... \"image\": \"xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/php:new\" ...}",
      "Of course \"latest\" can be anything.",
      "But I want to edit them in place and keep the whole JSON.",
      ".taskDefinition.containerDefinitions[].image |= sub(\"(?<repo>.*:).*\"; \"\\(.repo)new\")"
    ],
    "utterance": "Replace the tag after the colon in every containerDefinitions image field with 'new' while keeping the rest of the data structure unchanged.",
    "expressions": [
      ".taskDefinition.containerDefinitions[].image |= sub(\"(?<repo>.*:).*\"; \"\\(.repo)new\")"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "containerDefinitions": [
              {
                "name": "php",
                "image": "xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/php:latest",
                "cpu": 0,
                "memory": 512
              },
              {
                "name": "nginx",
                "image": "xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/nginx:latest",
                "cpu": 0,
                "memory": 256
              }
            ],
            "family": "service-be"
          }
        },
        "output": {
          "taskDefinition": {
            "containerDefinitions": [
              {
                "name": "php",
                "image": "xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/php:new",
                "cpu": 0,
                "memory": 512
              },
              {
                "name": "nginx",
                "image": "xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/nginx:new",
                "cpu": 0,
                "memory": 256
              }
            ],
            "family": "service-be"
          }
        }
      }
    ],
    "identifier": 55048593
  },
  {
    "context": [
      "The `\"final\"` holds an object which contains two keys: `name` and `content`. The `content` value is an object. It may be empty, and it may contains different keys.",
      "However, I am interested in certain keys if appeared in the `content`. In this example, if \"Type\" is included, I want to parse it. If not, just insert \"not found\".",
      "When I run this `jq` command, I get this error:\n\n    jq: error (at <stdin>:4): Cannot index string with string \"Type\"",
      "Since the value of the \"content\" field cannot be processed directly by `fromjson`, the following solution first translates the single-quotes to escaped double-quotes, and then applies your filter:\n\n    map(.final.content |= (gsub(\"'\";\"\\\"\") | fromjson))\n    | .[]\n    | \"\\(.start),\\(.final[\"name\"]),\\(.final[\"content\"][\"Type\"])\"",
      "If you want valid CSV output, it would probably be better to use the `@csv` filter:\n\n    .[]\n    | .final.content |= (gsub(\"'\";\"\\\"\") | fromjson)\n    | [.start, .final[\"name\"], .final[\"content\"][\"Type\"]]\n    | @csv",
      "If you want to handle missing values specially, you could use `//` e.g as follows:\n\n    (.final[\"content\"][\"Type\"] // \"NA\")"
    ],
    "utterance": "Extract start, final.name, and final.content[\"Type\"] for each object, replacing missing Type with a placeholder.",
    "expressions": [
      "map(.final.content |= (gsub(\"'\";\"\\\"\") | fromjson)) | .[] | \"\\(.start),\\(.final[\\\"name\\\"]),\\(.final[\\\"content\\\"][\\\"Type\\\"] // \\\"not found\\\")\"",
      ".[] | .final.content |= (gsub(\"'\";\"\\\"\") | fromjson) | [.start, .final[\"name\"], (.final[\"content\"][\"Type\"] // \"not found\")] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "start": "xxx",
            "final": {
              "name": "uuu",
              "content": "{'Date': 'Thu, 07 Mar 2019', 'Type': 'text'}"
            }
          },
          {
            "start": "yyy",
            "final": {
              "name": "nnn",
              "content": "{'Date': 'Thu, 07 Mar 2019'}"
            }
          }
        ],
        "output": [
          "xxx,uuu,text",
          "yyy,nnn,not found"
        ]
      }
    ],
    "identifier": 55045197
  },
  {
    "context": [
      "I can extract the lines with `awk '/{\"userData\"/{p=1}; p; /}\\./{p=0};'` which seems to be printing just fine.",
      "The difficulty I'm having is to run `jq` on each of the lines and extract the `json` fields. How can achieve this with a single `awk` command ?",
      "If every line in that file is a single json object immediately followed by a period, you could read the file in raw (which passes as input every line in the file as a string), strip out the period, then parse the json and process like normal.",
      "For example, dumping all user login names:",
      "$ jq -R '.[:-1] | fromjson | .userData[].user.loginName' input.txt"
    ],
    "utterance": "Extract all user login names from each object in a file where each line is a JSON object followed by a period.",
    "expressions": [
      ".[:-1] | fromjson | .userData[].user.loginName"
    ],
    "data": [
      {
        "input": "{\"userData\":[{\"user\":{\"loginName\":\"TEST\"}}]}.",
        "output": "TEST"
      },
      {
        "input": "{\"userData\":[{\"user\":{\"loginName\":\"TEST1\"}}]}.",
        "output": "TEST1"
      }
    ],
    "identifier": 54980112
  },
  {
    "context": [
      "jq -rc '[.id, .value] | @csv' |\n  awk -v NUM 100000 '{n++; print > \"out.\" int((n+NUM)/NUM) \".csv\"}'",
      "curl -L --silent \"$URL\" |\npigz -dc |\njq -r '[.name, .value] | @csv' |\nsplit -l 10000 --filter='save2db.php'"
    ],
    "utterance": "Produce CSVs with selected fields and split the output into multiple files or process in chunks of a specific number of lines (e.g., 10000) to avoid writing a single large file.",
    "expressions": [
      "[.name, .value] | @csv",
      "[.id, .value] | @csv"
    ],
    "identifier": 55192047
  },
  {
    "context": [
      "Trying to merge an undefined number of JSON files into one, each represented in their own key (using `jq`).",
      "For example: `foo` being the name of the first file and expected to be the key for its content in the final output.",
      "jq -n '[inputs | {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .}] | add' *.json"
    ],
    "utterance": "Combine multiple files so that each key is the filename (without the .json extension) and each value is the file's object content.",
    "expressions": [
      "jq -n '[inputs | {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .}] | add' *.json"
    ],
    "data": [
      {
        "input": [
          {
            "file": "foo.json",
            "content": {
              "test1": "Foo"
            }
          },
          {
            "file": "bar.json",
            "content": {
              "test2": "Bar"
            }
          }
        ],
        "output": {
          "foo": {
            "test1": "Foo"
          },
          "bar": {
            "test2": "Bar"
          }
        }
      }
    ],
    "identifier": 55001822
  },
  {
    "context": [
      "I am doing this using following jq commands:\r\n\r\n     proxy_host=`jq -r .proxy_host &lt;&lt;&lt; $line`\r\n     proxy_port=`jq -r .proxy_port &lt;&lt;&lt; $line`\r\n     query_string=`jq -r .query_string &lt;&lt;&lt; $line`\r\n     realip_remote_addr=`jq -r .realip_remote_addr &lt;&lt;&lt; $line`\r\n     ...\r\nMy json: ...",
      "Is there a way to simplify this using jq and bash not to have 30 independent jq invocations to get this done?",
      "Just do it once to dump all the key/value pairs and read them out in separate shell variables",
      "jq -r 'to_entries[] | [.key,.value] | join(\"=\")' json",
      "while IFS= read -d $'\\0' -r line; do\n    declare \"$line\"\ndone< <(data | jq -j -r 'to_entries[] | [.key, (.value | @sh)] | join(\"=\") + \"\\u0000\"' )",
      "Notice the use of the jq filter @sh."
    ],
    "utterance": "Extract all key-value pairs from the input as key=value strings, one per line, for sourcing as shell variables, with proper quoting for shell compatibility.",
    "expressions": [
      "to_entries[] | [.key,.value] | join(\"=\")",
      "-j -r 'to_entries[] | [.key, (.value | @sh)] | join(\"=\") + \"\\u0000\"'"
    ],
    "data": [
      {
        "input": {
          "host": "www.example.com",
          "hostname": "localhost",
          "proxy_add_x_forwarded_for": "127.0.0.1",
          "proxy_host": "",
          "proxy_port": "",
          "query_string": "",
          "realip_remote_addr": "8.1.2.3",
          "realpath_root": "/var/www/",
          "request_body": "",
          "request_id": "78e7cc17c207fc683992bae956150c4d",
          "request_method": "GET",
          "request_uri": "/",
          "scheme": "https",
          "server_name": "www.localhost.com",
          "ssl_protocol": "TLSv1.2",
          "ssl_ciphers": "AES128-GCM-SHA256:AES128-SHA:AES256-SHA:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:0x000a:0x00ff",
          "ssl_client_cert": "",
          "ssl_client_fingerprint": "",
          "ssl_client_i_dn": "",
          "ssl_client_raw_cert": "",
          "ssl_client_s_dn": "",
          "ssl_client_serial": "",
          "ssl_client_v_end": "",
          "ssl_client_v_remain": "",
          "ssl_client_v_start": "",
          "ssl_client_verify": "NONE",
          "ssl_session_id": "3e10c1253816aa4b3ea80df403e752fadaa1c6e532febd25e288acb4f5735617",
          "tcpinfo_rtt": "11142",
          "uri": "/index.html"
        },
        "output": [
          "host=www.example.com",
          "hostname=localhost",
          "proxy_add_x_forwarded_for=127.0.0.1",
          "proxy_host=",
          "proxy_port=",
          "query_string=",
          "realip_remote_addr=8.1.2.3",
          "realpath_root=/var/www/",
          "request_body=",
          "request_id=78e7cc17c207fc683992bae956150c4d",
          "request_method=GET",
          "request_uri=/",
          "scheme=https",
          "server_name=www.localhost.com",
          "ssl_protocol=TLSv1.2",
          "ssl_ciphers=AES128-GCM-SHA256:AES128-SHA:AES256-SHA:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:0x000a:0x00ff",
          "ssl_client_cert=",
          "ssl_client_fingerprint=",
          "ssl_client_i_dn=",
          "ssl_client_raw_cert=",
          "ssl_client_s_dn=",
          "ssl_client_serial=",
          "ssl_client_v_end=",
          "ssl_client_v_remain=",
          "ssl_client_v_start=",
          "ssl_client_verify=NONE",
          "ssl_session_id=3e10c1253816aa4b3ea80df403e752fadaa1c6e532febd25e288acb4f5735617",
          "tcpinfo_rtt=11142",
          "uri=/index.html"
        ]
      }
    ],
    "identifier": 55178069
  },
  {
    "context": [
      "So the *bar* object's property *myParameters* (the array containing two items) should be the template for all remaining objects (*FOO*, *BAZQUUX*, etc.) left, they should adopt the property of *bar*, discarding their existing properties.",
      "Is there a simple way to achieve this via jq?",
      "`.bar as $b | .[] |= $b`",
      "This assigns the object `bar` to the variable `$b` and replace all elements with this variable."
    ],
    "utterance": "Replace each top-level object's value with the value of 'bar', copying its properties to all top-level keys.",
    "expressions": [
      ".bar as $b | .[] |= $b"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "myParameters": [
              "first",
              "second",
              "third",
              "forth",
              "fifth"
            ]
          },
          "bar": {
            "myParameters": [
              "first",
              "third"
            ]
          },
          "BAZQUUX": {
            "myParameters": [
              "first",
              "second",
              "third",
              "forth",
              "fifth",
              "sixth",
              "seventh",
              "eighth",
              "ninth"
            ]
          }
        },
        "output": {
          "FOO": {
            "myParameters": [
              "first",
              "third"
            ]
          },
          "bar": {
            "myParameters": [
              "first",
              "third"
            ]
          },
          "BAZQUUX": {
            "myParameters": [
              "first",
              "third"
            ]
          }
        }
      }
    ],
    "identifier": 54887133
  },
  {
    "context": [
      "My incoming json looks like this:\r\n\r\n    [{\r\n\t\t\"ItemID\": 1,\r\n\t\t\"Size\": 10,\r\n\t\t\"Price\": 5\r\n\t},\r\n\t{\r\n\t\t\"ItemID\": 1,\r\n\t\t\"Size\": 11,\r\n\t\t\"Price\": 7\r\n\t},\r\n\t{\r\n\t\t\"ItemID\": 1,\r\n\t\t\"Size\": 12,\r\n\t\t\"Price\": 10\r\n\t},\r\n\t{\r\n\t\t\"ItemID\": 2,\r\n\t\t\"Size\": 11,\r\n\t\t\"Price\": 15\r\n\t},\r\n\t{\r\n\t\t\"ItemID\": 2,\r\n\t\t\"Size\": 12,\r\n\t\t\"Price\": 20\r\n\t}]\r\n\r\nAnd I need JSON to look like this:\r\n\r\n    [{\r\n\t\t\"ItemID\": 1,\r\n\t\t\"Price\": {\r\n\t\t\t\"10\": 5,\r\n\t\t\t\"11\": 7,\r\n\t\t\t\"12\": 10\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t\"ItemID\": 2,\r\n\t\t\"Price\": {\r\n\t\t\t\"11\": 15,\r\n\t\t\t\"12\": 20\r\n\t\t}\r\n\t}]\r\n",
      "After fixing the JSON, the following filter produces the output as shown below:\r\n\r\n    group_by(.ItemID)\r\n    | map( reduce .[] as $x ( .[0] | {ItemID};\r\n             .Price += ($x | {(.Size|tostring): .Price}) ) )"
    ],
    "utterance": "Group items by ItemID and produce an array where each element contains ItemID and a Price object mapping Size (as string) to Price.",
    "expressions": [
      "group_by(.ItemID)\n| map( reduce .[] as $x ( .[0] | {ItemID};\n         .Price += ($x | {(.Size|tostring): .Price}) ) )"
    ],
    "data": [
      {
        "input": [
          {
            "ItemID": 1,
            "Size": 10,
            "Price": 5
          },
          {
            "ItemID": 1,
            "Size": 11,
            "Price": 7
          },
          {
            "ItemID": 1,
            "Size": 12,
            "Price": 10
          },
          {
            "ItemID": 2,
            "Size": 11,
            "Price": 15
          },
          {
            "ItemID": 2,
            "Size": 12,
            "Price": 20
          }
        ],
        "output": [
          {
            "ItemID": 1,
            "Price": {
              "10": 5,
              "11": 7,
              "12": 10
            }
          },
          {
            "ItemID": 2,
            "Price": {
              "11": 15,
              "12": 20
            }
          }
        ]
      }
    ],
    "identifier": 55052588
  },
  {
    "context": [
      "I have a huge json file which has its keys starting with a \"/\". I wanted to create multiple json file based on the key name.",
      "how do I replace the first string \"/\" in every key to a blank space?",
      "Can I get some help, please?"
    ],
    "utterance": "Remove the leading slash from each key before using it as a filename for creating separate files by key.",
    "expressions": [
      "jq -r 'keys[] | ltrimstr(\"/\")' input.json"
    ],
    "identifier": 55177098
  },
  {
    "context": [
      "Given the following structure:",
      "Using only `jq`, is there a way to transform it to the following structure? ",
      "This works:",
      "map(. + {authorizedKey: {\"0\": \"zero\", \"1\": \"one\"}[.authorizedKey]})",
      "If there are other values besides 0 and 1, you can add them to the map. If you have a bunch more and you want to improve readability, you could do this:",
      "{\"0\": \"zero\", \"1\": \"one\"} as $mapping | map(. + {authorizedKey: $mapping[.authorizedKey]})"
    ],
    "utterance": "Replace the authorizedKey field in each object from '0' or '1' to the corresponding word 'zero' or 'one'.",
    "expressions": [
      "map(. + {authorizedKey: {\"0\": \"zero\", \"1\": \"one\"}[.authorizedKey]})",
      "{\"0\": \"zero\", \"1\": \"one\"} as $mapping | map(. + {authorizedKey: $mapping[.authorizedKey]})"
    ],
    "data": [
      {
        "input": [
          {
            "authorizedKey": "0",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "aaa12345-1234-1234-1234-1234567890ab"
          },
          {
            "authorizedKey": "1",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "bbb12345-1234-1234-1234-1234567890ab"
          },
          {
            "authorizedKey": "1",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "ccc12345-1234-1234-1234-1234567890ab"
          }
        ],
        "output": [
          {
            "authorizedKey": "zero",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "aaa12345-1234-1234-1234-1234567890ab"
          },
          {
            "authorizedKey": "one",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "bbb12345-1234-1234-1234-1234567890ab"
          },
          {
            "authorizedKey": "one",
            "description": "This key is for system testing.",
            "keyExpiration": "2035-02-02T18:28:59Z",
            "keyId": "ccc12345-1234-1234-1234-1234567890ab"
          }
        ]
      }
    ],
    "identifier": 54875776
  },
  {
    "context": [
      "But this seems to take issue with the (valid) spaces in the strings.  Output:",
      "Use a `while` to read entire lines, rather than iterating over the *words* resulting from the command substitution.",
      "while IFS= read -r obj; do\n    ...\ndone < <(jq -c '.[]' posts.json)",
      "jq -M -c '.[] | [.post_type, .post_title, .post_content, .post_status][]' \\\nposts.json | xargs -n4 ./wpfunction",
      "jq -r '.[] | [\"post\", \"create\", (to_entries[] | \"--\\(.key)=\\(.value|tojson)\")] | @sh' input.json | xargs wp"
    ],
    "utterance": "Iterate over each object in the array, preserving spaces and special characters, to extract all fields for use as arguments in a shell command.",
    "expressions": [
      "jq -c '.[]' posts.json",
      "jq -M -c '.[] | [.post_type, .post_title, .post_content, .post_status][]' posts.json",
      "jq -r '.[] | [\"post\", \"create\", (to_entries[] | \"--\\(.key)=\\(.value|tojson)\")] | @sh' input.json"
    ],
    "data": [
      {
        "input": [
          {
            "post_type": "post",
            "post_title": "Test",
            "post_content": "[leaflet-map][leaflet-marker]",
            "post_status": "publish"
          },
          {
            "post_type": "post",
            "post_title": "Number 2",
            "post_content": "[leaflet-map fitbounds][leaflet-circle]",
            "post_status": "publish"
          }
        ]
      }
    ],
    "identifier": 54952736
  },
  {
    "context": [
      "I need to lookup the \"label\" by value in translation.json and replace the \"label\" value in Form.json with the \"tranlsation\" value from translation.json.",
      ".label |= if $dict.label == . then $dict.translation else . end",
      "if .label == $dict.label then .label = $dict.translation else . end",
      ".label |= if $dict.label == . then $dict.translation end",
      "if .label == $dict.label then .label = $dict.translation end"
    ],
    "utterance": "Replace the value of \"label\" in the input where it matches the \"label\" value from another file, using the corresponding \"translation\" value.",
    "expressions": [
      ".label |= if $dict.label == . then $dict.translation else . end",
      "if .label == $dict.label then .label = $dict.translation else . end",
      ".label |= if $dict.label == . then $dict.translation end",
      "if .label == $dict.label then .label = $dict.translation end"
    ],
    "data": [
      {
        "input": {
          "fullName": "Student_Information/Preferred_Name__pc",
          "description": "Preferred Name",
          "inlineHelpText": "Preferred Name",
          "label": "Preferred Name"
        },
        "output": {
          "fullName": "Student_Information/Preferred_Name__pc",
          "description": "Preferred Name",
          "inlineHelpText": "Preferred Name",
          "label": "Nombre Preferido"
        }
      }
    ],
    "identifier": 54964527
  },
  {
    "context": [
      "I\u2019m trying to filter out arrays that don\u2019t contain the number '32' but it only filters out those that contain just one integer.",
      "But upon running:\n\n    select(.tags[] == 32 | not)\nI still get one array containing 32.",
      "This should do the job:\n\n    select(.tags | contains([32]) | not)"
    ],
    "utterance": "Filter objects whose 'tags' array does not contain the number 32.",
    "expressions": [
      "select(.tags | contains([32]) | not)"
    ],
    "data": [
      {
        "input": [
          {
            "tags": [
              21
            ]
          },
          {
            "tags": [
              32
            ]
          },
          {
            "tags": [
              21,
              32
            ]
          }
        ],
        "output": [
          {
            "tags": [
              21
            ]
          }
        ]
      }
    ],
    "identifier": 54900788
  },
  {
    "context": [
      "I get the desired result however, I also get the jq error at the end of the result. Just curious to know what am I doing incorrectly with the query.",
      "Since your input is large, you might consider adding assertions or equivalent.",
      "Your program could then be instrumented as follows:",
      "range(0;length) as $n\n  | .[$n]\n  | .\"lrouter/show\" | q($n; 2) | .[]\n  | del( . | select(.type == \"TUNNEL-VRF\"))\n  | del(.ports | q($n; 3) | .[] | select(.type == \"blackhole\" or .type == \"cpu-port\" or .type == \"loopback\"))\n  | \"Name: \\(.name)\" ,\n    \"UUID: \\(.uuid)\" ,\n   (.ports[] | {Port_Name: .name,\n                Port_Type: .type, \n                Port_Peer: .peer,\n                Port_IPs: (.ips | q($n; 4) |.[]),\n                Port_Admin_Up: .admin_up, \n                Port_Op_State: .op_state_up } )"
    ],
    "utterance": "List router names, UUIDs, and filtered port details for all routers, skipping objects of type \"TUNNEL-VRF\" and ports of type \"blackhole\", \"cpu-port\", or \"loopback\"; avoid errors when nulls are present.",
    "expressions": [
      "def q($n; $msg): if type == \"array\" or type == \"object\" then . else error(\"\\($msg): composite expected @ \\($n) vs \\(.)\") end;\nrange(0;length) as $n\n  | .[$n]\n  | .\"lrouter/show\" | q($n; 2) | .[]\n  | del( . | select(.type == \"TUNNEL-VRF\"))\n  | del(.ports | q($n; 3) | .[] | select(.type == \"blackhole\" or .type == \"cpu-port\" or .type == \"loopback\"))\n  | \"Name: \\(.name)\" ,\n    \"UUID: \\(.uuid)\" ,\n   (.ports[] | {Port_Name: .name,\n                Port_Type: .type,\n                Port_Peer: .peer,\n                Port_IPs: (.ips | q($n; 4) |.[]),\n                Port_Admin_Up: .admin_up,\n                Port_Op_State: .op_state_up } )"
    ],
    "identifier": 55151711
  },
  {
    "context": [
      "Now the field I actually want is coming from the shell and is given to `jq` as an argument like this:",
      "<file jq --arg myarg \"foo\" '{$myarg}'",
      "Unfortunately this doesn't give the expected result {\"foo\":\"hello\"}.",
      "A workaround to this is to explicitly defined the object:",
      "<file jq '{($myarg):.[$myarg]}'",
      "The method described in the Q is the preferred one, but for the record, here are two alternatives:",
      "jq --arg myarg \"foo\" '\n  .[$myarg] as $v | {} | .[$myarg] = $v'",
      "myarg=foo ; jq \"{ $myarg }\""
    ],
    "utterance": "Output an object with a single property whose key is provided as a command-line argument and whose value is the corresponding value from the input for that key",
    "expressions": [
      "{($myarg): .[$myarg]}",
      ".[$myarg] as $v | {} | .[$myarg] = $v"
    ],
    "data": [
      {
        "input": {
          "foo": "hello",
          "bar": "world"
        },
        "output": {
          "foo": "hello"
        }
      }
    ],
    "identifier": 55060292
  },
  {
    "context": [
      "curl -s  http://<jenkins_url>/job/<job_name>/lastCompletedBuild/api/json | jq .\"result\"",
      "For /F \"Delims=\" %%A In ('\"curl -s  http://<jenkins_url>/job/<job_name>/lastCompletedBuild/api/json | jq .\"result\"\"') Do Set \"test=%%~A\""
    ],
    "utterance": "Extract the value of the top-level field named result from the data returned by a Jenkins build API.",
    "expressions": [
      ".result"
    ],
    "identifier": 55085812
  },
  {
    "context": [
      "if I want to generate a ndjson, which have two fields. One is \"timestamp\" which go through 2019-02-23T00:00, 2019-02-23T00:01, ..., 2019-02-24T23:59 (timestamps by minutes) and count the uniques of distinct device_id that is active by every timestamps.",
      "As I understand it, you want (for each \"minute\") a count of the number of active devices. Here is a solution that assumes that the input specifies non-overlapping intervals for each \"device_id\":",
      "def seconds:\n    # strips fractional seconds\n    \"\\(.[:-5])Z\" | fromdateiso8601;\n\ndef record($s; $e):\n  reduce range($s | round; $e + 1) as $i (.; .[$i|todate] += 1);\n\nreduce inputs as $in ({}; record( ($in | .start_time_first | seconds / 60); ($in | .start_time_last | seconds / 60)))"
    ],
    "utterance": "For each minute in a given period, count how many unique device_id values are active during that minute.",
    "expressions": [
      "def seconds:\n    \"\\(.[:-5])Z\" | fromdateiso8601;\n\ndef record($s; $e):\n  reduce range($s | round; $e + 1) as $i (.; .[$i|todate] += 1);\n\nreduce inputs as $in ({}; record( ($in | .start_time_first | seconds / 60); ($in | .start_time_last | seconds / 60)))"
    ],
    "data": [
      {
        "input": [
          {
            "start_time_last": "2019-02-24T00:07:25.875Z",
            "start_time_first": "2019-02-24T00:07:25.875Z",
            "device_id": "8160a3f87a977379f12f8826fd3c9c86ca3ca48a"
          },
          {
            "start_time_last": "2019-02-24T00:48:56.100Z",
            "start_time_first": "2019-02-24T00:40:24.464Z",
            "device_id": "181606aabbf155217f59e302541638bfc7e07837"
          },
          {
            "start_time_last": "2019-02-23T21:57:36.024Z",
            "start_time_first": "2019-02-23T21:56:06.741Z",
            "device_id": "1b62573cdfdab3902b72ec9e4797c422271f2efd"
          }
        ]
      }
    ],
    "identifier": 54914675
  },
  {
    "context": [
      "How do I go about inserting the `name` key-value pair to the object in the `file2.json`. The output I'm trying to get is as follows:",
      "You will need to \"slurp\" file1.json, e.g. by invoking jq as follows:",
      "jq -n -f merge.jq --slurpfile file1 file1.json file2.json",
      "where merge.jq contains:",
      "INDEX($file1[]; .uid) as $dict | inputs | . + $dict[.uid]",
      "If your jq does not have INDEX/2, then simply add its def:",
      "def INDEX(stream; idx_expr): reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row);"
    ],
    "utterance": "For each object in file2, add the matching name based on uid from file1.",
    "expressions": [
      "INDEX($file1[]; .uid) as $dict | inputs | . + $dict[.uid]",
      "def INDEX(stream; idx_expr): reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row); INDEX($file1[]; .uid) as $dict | inputs | . + $dict[.uid]"
    ],
    "data": [
      {
        "input": [
          {
            "uid": "1",
            "name": "jack"
          },
          {
            "uid": "2",
            "name": "jill"
          }
        ],
        "output": [
          {
            "fid": "a",
            "file": "sample1.txt",
            "uid": "1",
            "name": "jack"
          },
          {
            "fid": "b",
            "file": "sample2.txt",
            "uid": "1",
            "name": "jack"
          },
          {
            "fid": "c",
            "file": "sample3.txt",
            "uid": "2",
            "name": "jill"
          }
        ]
      }
    ],
    "identifier": 54974458
  },
  {
    "context": [
      "I would like to end up with something like .....\n\n>   \u201caccount_id\u201d: 1030907370,   \u201cglobal_rating\u201d: 3906\n> \n>   \u201caccount_id\u201d: 1020786770,   \u201cglobal_rating\u201d: 3906\n> \n>   \u201caccount_id\u201d: 1018984431,   \u201cglobal_rating\u201d: 3906",
      "The key here to accessing the key names is to use `keys`, `keys_unsorted`, or `to_entries`, e.g.\n\n    .data\n    | to_entries[]\n    | \"\\\"account_id\\\": \\(.key): \\\"global_rating\\\": \\(.value.global_rating)\"",
      "If you wanted the output in the form of a stream of JSON objects:\n\n    | .data\n    | to_entries[]\n    | {account_id: .key} + (.value | {global_rating})"
    ],
    "utterance": "Produce a stream of objects with each account's account_id and global_rating, extracting the account_id from both the object key and value.",
    "expressions": [
      ".data | to_entries[] | {account_id: .key} + (.value | {global_rating})"
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "meta": {
            "count": 3
          },
          "data": {
            "1030907370": {
              "client_language": "en",
              "last_battle_time": 1548555418,
              "account_id": 1030907370,
              "created_at": 1525288212,
              "updated_at": 1548557165,
              "private": null,
              "global_rating": 3906,
              "clan_id": null,
              "nickname": "aaa",
              "logout_at": 1548557161
            },
            "1020786770": {
              "client_language": "ja",
              "last_battle_time": 1548948444,
              "account_id": 1020786770,
              "created_at": 1465998341,
              "updated_at": 1548948547,
              "private": null,
              "global_rating": 4396,
              "clan_id": null,
              "nickname": "bbb",
              "logout_at": 1548948544
            },
            "1018984431": {
              "client_language": "en",
              "last_battle_time": 1548550089,
              "account_id": 1018984431,
              "created_at": 1456254986,
              "updated_at": 1548550089,
              "private": null,
              "global_rating": 1666,
              "clan_id": null,
              "nickname": "ccc",
              "logout_at": 1548550016
            }
          }
        },
        "output": [
          {
            "account_id": "1030907370",
            "global_rating": 3906
          },
          {
            "account_id": "1020786770",
            "global_rating": 4396
          },
          {
            "account_id": "1018984431",
            "global_rating": 1666
          }
        ]
      }
    ],
    "identifier": 54483059
  },
  {
    "context": [
      "Input:\r\n\r\n    {\"aa\":[\"a1\",\"a2\"]}\r\n    {\"bb\":[\"a1\",\"b2\"]}",
      "Wanted output (no worries about potentially duplicate keys):\r\n\r\n    {\r\n      \"aa\":[\"a1\",\"a2\"],\r\n      \"bb\":[\"b1\",\"b2\"]\r\n    }",
      "The simplest would undoubtedly be to use the invocation:\r\n\r\n    jq -s add",
      "If the input stream is extremely large, it might be better to use reduction, e.g.:\r\n\r\n    jq -n 'reduce inputs as $i ({}; . + $i)'"
    ],
    "utterance": "Combine multiple line-delimited objects into a single object that merges all top-level keys.",
    "expressions": [
      "-s add",
      "-n 'reduce inputs as $i ({}; . + $i)'"
    ],
    "data": [
      {
        "input": [
          {
            "aa": [
              "a1",
              "a2"
            ]
          },
          {
            "bb": [
              "a1",
              "b2"
            ]
          }
        ],
        "output": {
          "aa": [
            "a1",
            "a2"
          ],
          "bb": [
            "a1",
            "b2"
          ]
        }
      }
    ],
    "identifier": 55150415
  },
  {
    "context": [
      "I have a file in a subset of YAML with data such as the below:\n\n```\n# This is a comment\n# This is another comment\n\n\nspark:spark.ui.enabled: 'false'\nspark:spark.sql.adaptive.enabled: 'true'\nyarn:yarn.nodemanager.log.retain-seconds: '259200'\n\n\n```",
      "I need to convert that into a JSON document looking like this (note that strings containing booleans and integers still remain strings):\n\n```json\n{\n  \"spark:spark.ui.enabled\": \"false\",\n  \"spark:spark.sql.adaptive.enabled\": \"true\",\n  \"yarn:yarn.nodemanager.log.retain-seconds\", \"259200\"\n}\n```",
      "Implemented in pure `jq` (tested with version 1.6):\n\n```\n#!/usr/bin/env bash\n\njq_script=$(cat <<'EOF'\ndef content_for_line:\n  \"^[[:space:]]*([#]|$)\" as $ignore_re |           # regex for comments, blank lines\n  \"^(?<key>.*): (?<value>.*)$\" as $content_re |    # regex for actual k/v pairs\n  \"^'(?<value>.*)'$\" as $quoted_re |               # regex for values in single quotes\n  if test($ignore_re) then {} else                 # empty lines add nothing to the data\n    if test($content_re) then (                    # non-empty: match against $content_re\n      capture($content_re) as $content |           # ...and put the groups into $content\n      $content.key as $key |                       # string before \": \" becomes $key\n      (if ($content.value | test($quoted_re)) then # if value contains literal quotes...\n         ($content.value | capture($quoted_re)).value # ...take string from inside quotes\n       else\n         $content.value                               # no quotes to strip\n       end) as $value |                     # result of the above block becomes $value\n      {\"\\($key)\": \"\\($value)\"}              # and return a map from one key to one value\n    ) else\n      # we get here if a line didn't match $ignore_re *or* $content_re\n      error(\"Line \\(.) is not recognized as a comment, empty, or valid content\")\n    end\n  end;\n\n# iterate over our input lines, passing each one to content_for_line and merging the result\n# into the object we're building, which we eventually return as our result.\nreduce inputs as $item ({}; . + ($item | content_for_line))\nEOF\n)\n\n# jq -R: read input as raw strings\n# jq -n: don't read from stdin until requested with \"input\" or \"inputs\"\njq -Rn \"$jq_script\" <file.yaml >file.json\n```",
      "Here\u2019s a no-frills but simple solution:\n\n\ndef tidy: sub(\"^ *'?\";\"\") | sub(\" *'?$\";\"\");\ndef kv: split(\":\") | [ (.[:-1] | join(\":\")), (.[-1]|tidy)];\n\nreduce (inputs| select( test(\"^ *#|^ *$\")|not) | kv) as $row ({};\n\t.[$row[0]] = $row[1] )\n\n\n### Invocation\n\n    jq -n -R -f tojson.jq input.txt"
    ],
    "utterance": "Transform a key:value configuration file (with comments and quoted values) into an object mapping keys to string values, ignoring comments and blank lines, and preserving values as strings even if they look like booleans or numbers.",
    "expressions": [
      "def content_for_line:\n  \"^[[:space:]]*([#]|$)\" as $ignore_re |\n  \"^(?<key>.*): (?<value>.*)$\" as $content_re |\n  \"^'(?<value>.*)'$\" as $quoted_re |\n  if test($ignore_re) then {} else\n    if test($content_re) then (\n      capture($content_re) as $content |\n      $content.key as $key |\n      (if ($content.value | test($quoted_re)) then\n         ($content.value | capture($quoted_re)).value\n       else\n         $content.value\n       end) as $value |\n      {\"\\($key)\": \"\\($value)\"}\n    ) else\n      error(\"Line \\(.) is not recognized as a comment, empty, or valid content\")\n    end\n  end;\nreduce inputs as $item ({}; . + ($item | content_for_line))",
      "def tidy: sub(\"^ *'?\";\"\") | sub(\" *'?$\";\"\");\ndef kv: split(\":\") | [ (.[:-1] | join(\":\")), (.[-1]|tidy)];\nreduce (inputs| select( test(\"^ *#|^ *$\")|not) | kv) as $row ({};\n\t.[$row[0]] = $row[1] )"
    ],
    "data": [
      {
        "input": "# This is a comment\n# This is another comment\n\nspark:spark.ui.enabled: 'false'\nspark:spark.sql.adaptive.enabled: 'true'\nyarn:yarn.nodemanager.log.retain-seconds: '259200'\n",
        "output": {
          "spark:spark.ui.enabled": "false",
          "spark:spark.sql.adaptive.enabled": "true",
          "yarn:yarn.nodemanager.log.retain-seconds": "259200"
        }
      }
    ],
    "identifier": 55069082
  },
  {
    "context": [
      "The goal is to return the JSON stripped of the top two (`content` and `data`) levels, and with the properties of `notes` stripped out if there isn\u2019t a `types` tag starting with 'x' or 'y' for that note.",
      ".content.data  | .hits[].doc.notes |= map ( if ( .types | any(startswith(\"x\") or startswith(\"y\"))) then . else empty end )",
      "The relevant helper function in the present case implements the stripping-out requirement:",
      "def prune:\n   to_entries\n   | map( select( any(.value.types[]; test(\"^(x|y)\")) ) )\n   | from_entries ;",
      ".content.data | .hits |= map( .doc.notes |= prune )"
    ],
    "utterance": "Remove top-level keys 'content' and 'data', then for each 'hits[].doc.notes', keep only those notes whose 'types' array contains at least one string starting with 'x' or 'y'.",
    "expressions": [
      ".content.data  | .hits[].doc.notes |= map ( if ( .types | any(startswith(\"x\") or startswith(\"y\"))) then . else empty end )",
      "def prune: to_entries | map( select( any(.value.types[]; test(\"^(x|y)\")) ) ) | from_entries ; .content.data | .hits |= map( .doc.notes |= prune )"
    ],
    "data": [
      {
        "input": {
          "content": {
            "data": {
              "meta": "stuff",
              "hits": [
                {
                  "doc": {
                    "id": "10",
                    "notes": {
                      "f1": {
                        "name": "F1",
                        "types": [
                          "wwwa",
                          "zzzb"
                        ]
                      },
                      "f2": {
                        "name": "F2",
                        "types": [
                          "xxxa",
                          "yyya"
                        ]
                      }
                    }
                  },
                  "score": "1"
                },
                {
                  "doc": {
                    "id": "11",
                    "notes": {
                      "f1": {
                        "name": "F1",
                        "types": [
                          "wwwa",
                          "zzzb"
                        ]
                      },
                      "f3": {
                        "name": "F3",
                        "types": [
                          "qzxb",
                          "xxxb"
                        ]
                      }
                    }
                  },
                  "score": "2"
                }
              ]
            }
          }
        },
        "output": {
          "meta": "stuff",
          "hits": [
            {
              "doc": {
                "id": "10",
                "notes": {
                  "f2": {
                    "name": "F2",
                    "types": [
                      "xxxa",
                      "yyya"
                    ]
                  }
                }
              },
              "score": "1"
            },
            {
              "doc": {
                "id": "11",
                "notes": {
                  "f3": {
                    "name": "F3",
                    "types": [
                      "qzxb",
                      "xxxb"
                    ]
                  }
                }
              },
              "score": "2"
            }
          ]
        }
      }
    ],
    "identifier": 54909977
  },
  {
    "context": [
      "I want to convert the following json:\r\n\r\n    {                                                    \r\n      \"hello\": \"world\",                                \r\n      \"foo\": \"bar\"        \r\n    }\r\n\r\nto\r\n\r\n    {\r\n    \t\"parent_key\": {\r\n    \t\t\"hello\": {\r\n    \t\t\t\"value\": \"world\"\r\n    \t\t},\r\n    \t\t\"foo\": {\r\n    \t\t\t\"value\": \"bar\"\r\n    \t\t}\r\n    \t}\r\n    }",
      "{ parent_key: map_values( {value: .}) }"
    ],
    "utterance": "Wrap all key-value pairs in a parent key and move each value into an object with the key 'value'.",
    "expressions": [
      "{ parent_key: map_values({value: .}) }"
    ],
    "data": [
      {
        "input": {
          "hello": "world",
          "foo": "bar"
        },
        "output": {
          "parent_key": {
            "hello": {
              "value": "world"
            },
            "foo": {
              "value": "bar"
            }
          }
        }
      }
    ],
    "identifier": 55147669
  },
  {
    "context": [
      "i want to remove square brackets as illustrated in this example:",
      "Input file : file1.json",
      "{ \"regex_features\": [\n      [ // This bracket needs to be removed\n        {\n          \"name\": \"jobname\",\n          \"pattern\": \"[A-Z]+-[0-9]\"\n        },\n        {\n          \"name\": \"project\",\n          \"pattern\": \"[A-Z]{4}\"\n        },\n        {\n          \"name\": \"summary\",\n          \"pattern\": \"[a-z]+[a-z]+[a-z]{4}\"\n        },\n        {\n          \"name\": \"description\",\n          \"pattern\": \"[a-z]+[a-z]+[a-z]+[a-z]{4}\"\n        }\n      ] // this bracket needs to be removed. \n     ]\n}",
      "You can use the update assignment operator to replace the list by its first element (which is the inner list):",
      "jq '.regex_features|=.[0]' file.json"
    ],
    "utterance": "Flatten the nested array within the 'regex_features' property by removing the inner square brackets.",
    "expressions": [
      ".regex_features |= .[0]"
    ],
    "data": [
      {
        "input": {
          "name": "foo",
          "regex_features": [
            [
              {
                "name": "jobname",
                "pattern": "[A-Z]+-[0-9]"
              },
              {
                "name": "project",
                "pattern": "[A-Z]{4}"
              }
            ]
          ]
        },
        "output": {
          "name": "foo",
          "regex_features": [
            {
              "name": "jobname",
              "pattern": "[A-Z]+-[0-9]"
            },
            {
              "name": "project",
              "pattern": "[A-Z]{4}"
            }
          ]
        }
      }
    ],
    "identifier": 55061437
  },
  {
    "context": [
      "curl --request POST --form \"file=@tag.txt\" https://gitlab.com/api/v4/projects/:id/uploads?private_token=<myToken> | jq .markdown",
      "The response I get from the curl looks like this: ",
      "{\"alt\":\"tag.txt\",\"url\":\"/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt\",\"markdown\":\"[tag.txt](/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt)\"}"
    ],
    "utterance": "Extract the value associated with the key 'markdown' from the response object.",
    "expressions": [
      ".markdown"
    ],
    "data": [
      {
        "input": {
          "alt": "tag.txt",
          "url": "/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt",
          "markdown": "[tag.txt](/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt)"
        },
        "output": "[tag.txt](/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt)"
      }
    ],
    "identifier": 55052690
  },
  {
    "context": [
      "For example I want a full path to the key value: **9i6O4ERWWB**",
      "Once knowing the key path:  **_source.example.com.template1**  I want to increment the \"counter\" field and update the elasticsearch document.",
      "Expected result:   `[\"_source\",\"statistics\",\"example.com\",\"template1\",\"subdomain_id\":\"432432sdxWWB\"]`",
      "jq -c 'paths(scalars) as $p | [$p, getpath($p)]' file.json | grep 432432sdxWWB",
      "jq -c 'paths(scalars) as $p\n| [$p, getpath($p)]\n| select(.[1] == \"9i6O4ERWWB\")' input.json"
    ],
    "utterance": "Find the full key path to the value '9i6O4ERWWB', including exact path elements, regardless of unknown intermediate key names.",
    "expressions": [
      "paths(scalars) as $p | [$p, getpath($p)] | select(.[1] == \"9i6O4ERWWB\")"
    ],
    "data": [
      {
        "input": {
          "_index": "domains",
          "_type": "doc",
          "_id": "c66443eb1e6a0850b03a91fdb967f4d1",
          "_score": 2.4877305,
          "_source": {
            "user_id": "c66443eb1e6a0850b03a91fdb967f4d1",
            "statistics": {
              "test_count": 0,
              "datasize": 0,
              "example.com": {
                "template1": {
                  "image_id": "iPpDWbaO3YTIEb0pBkW3.png",
                  "link_id": "4ybOOUJpaBpDaLxPkz1j.html",
                  "counter": 0,
                  "subdomain_id": "9i6O4ERWWB"
                },
                "template2": {
                  "image_id": "iPpDWasdas322sdaW3.png",
                  "link_id": "4ybOOd3425sdfsz1j.html",
                  "counter": 1,
                  "subdomain_id": "432432sdxWWB"
                }
              },
              "example1.com": {
                "template1": {
                  "image_id": "iPpDWdasdasdasdas3.png",
                  "link_id": "4ybOOUadsasdadsasd1j.html",
                  "subdomain_id": "9i6O4ERWWB"
                }
              }
            }
          }
        },
        "output": [
          [
            [
              "_source",
              "statistics",
              "example.com",
              "template1",
              "subdomain_id"
            ],
            "9i6O4ERWWB"
          ],
          [
            [
              "_source",
              "statistics",
              "example1.com",
              "template1",
              "subdomain_id"
            ],
            "9i6O4ERWWB"
          ]
        ]
      }
    ],
    "identifier": 55137976
  },
  {
    "context": [
      "An example of additional manipulations I want to do for the above input, is: select based on particular values of chef_environment and for those, output the key and availability zone, e.g.",
      "i-f9aa,us-east-1b",
      "The jq function `to_entries` will transform `{ \"KEY\": \"VALUE\" }` to `{ \"key\": \"KEY\", \"value\": \"VALUE\" }`.",
      ".rows[] | to_entries[] |  [.key, .value[\"ec2.placement_availability_zone\"]] | @csv",
      "...given your input, outputs (when run in raw mode):",
      "\"i-0cf0\",\"us-east-1d\"",
      "\"i-f9aa\",\"us-east-1b\""
    ],
    "utterance": "For each object in rows, where chef_environment equals alpha-qa, output the key and ec2.placement_availability_zone as a CSV row.",
    "expressions": [
      ".rows[] | to_entries[] | select(.value.chef_environment == \"alpha-qa\") | [.key, .value[\"ec2.placement_availability_zone\"]] | @csv"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "i-0cf0": {
                "chef_environment": "alpha-prod",
                "ec2.placement_availability_zone": "us-east-1d"
              }
            },
            {
              "i-f9aa": {
                "chef_environment": "alpha-qa",
                "ec2.placement_availability_zone": "us-east-1b"
              }
            }
          ]
        },
        "output": "\"i-f9aa\",\"us-east-1b\""
      }
    ],
    "identifier": 54777015
  },
  {
    "context": [
      "How can I construct a stream where each object from `object_count.json` is attributed with its respective class name? I.e.:",
      "{\n    \"name\":\"apple\",\n    \"count\":10\n    \"class\":\"fruit\"\n}\n{\n    \"name\":\"potato\",\n    \"count\":18\n    \"class\":\"vegetable\"\n}\n{\n    \"name\":\"stone\",\n    \"count\":7\n    \"class\":\"other\"\n}",
      "works well 3, 4 and more classes--each still listed in a separate file; it's OK if each class is hardcoded",
      "`object_count.json` is considered an input stream, while `{fruits|vegetables}.txt` are provided each as a separate `--rawfile` argument",
      "the invocation of jq will look like this:\n\n    jq -n -R -f program.jq --slurpfile input object_count.json *.txt",
      "dictionary(inputs) as $class\n| $input[]\n| .class = ($class[.name] // \"other\")",
      "jq --argfile class <(jq -n -R -f dictionary.jq *.txt)  '\n .class = ($class[.name] // \"other\")'  object_count.json"
    ],
    "utterance": "For each object, add a key whose value is the class it belongs to as defined in one of several class files, using 'other' if its name is absent from all class files.",
    "expressions": [
      "dictionary(inputs) as $class | $input[] | .class = ($class[.name] // \"other\")",
      ".class = ($class[.name] // \"other\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "apple",
            "count": 10
          },
          {
            "name": "potato",
            "count": 18
          },
          {
            "name": "stone",
            "count": 7
          }
        ],
        "output": [
          {
            "name": "apple",
            "count": 10,
            "class": "fruit"
          },
          {
            "name": "potato",
            "count": 18,
            "class": "vegetable"
          },
          {
            "name": "stone",
            "count": 7,
            "class": "other"
          }
        ]
      }
    ],
    "identifier": 55087333
  },
  {
    "context": [
      "I need to merge the same ids by **lang** field. Final file should looks like:",
      "$ jq -n '\n{Pack: ([inputs.Pack[]] | group_by(.id) | map({id: .[0].id, lang: (map(.lang) | add)}))}\n' file*.json",
      "This results in:\n{\n  \"Pack\": [\n    {\n      \"id\": \"item1\",\n      \"lang\": {\n        \"en\": {},\n        \"sp\": {}\n      }\n    },\n    {\n      \"id\": \"item2\",\n      \"lang\": {\n        \"en\": {}\n      }\n    }\n  ]\n}\n"
    ],
    "utterance": "Merge objects from multiple files by matching id, combining their lang fields so that each id has all corresponding language entries merged together.",
    "expressions": [
      "{Pack: ([inputs.Pack[]] | group_by(.id) | map({id: .[0].id, lang: (map(.lang) | add)}))}"
    ],
    "data": [
      {
        "input": [
          {
            "Pack": [
              {
                "id": "item1",
                "lang": {
                  "en": {}
                }
              },
              {
                "id": "item2",
                "lang": {
                  "en": {}
                }
              }
            ]
          },
          {
            "Pack": [
              {
                "id": "item1",
                "lang": {
                  "sp": {}
                }
              }
            ]
          }
        ],
        "output": {
          "Pack": [
            {
              "id": "item1",
              "lang": {
                "en": {},
                "sp": {}
              }
            },
            {
              "id": "item2",
              "lang": {
                "en": {}
              }
            }
          ]
        }
      }
    ],
    "identifier": 54870363
  },
  {
    "context": [
      "I want to separate \"hw-name\" from this JSON file using jq.",
      "cat jsonfile | jq -r '.comment[].hw-name'",
      "cat json_file.json | jq -r '.comment[].site-ops-updates[].hw-name'",
      "cat jsonfile | jq -r '.comment.\"site-ops-updates\"[].\"hw-name\"'",
      "jq -r '.comment.\"site-ops-updates\"[].\"hw-name\"' jsonfile",
      "If the key contains special characters, you need to surround it with double quotes like this: .\"foo$\", or else .[\"foo$\"]"
    ],
    "utterance": "Extract all values of the 'hw-name' field from the 'site-ops-updates' array inside the 'comment' object.",
    "expressions": [
      ".comment[\"site-ops-updates\"][].hw-name",
      ".comment.\"site-ops-updates\"[].\"hw-name\""
    ],
    "data": [
      {
        "input": {
          "comment": {
            "vm-updates": [],
            "site-ops-updates": [
              {
                "comment": {
                  "message": "You can start maintenance on this resource"
                },
                "hw-name": "Machine has got missing disks. "
              }
            ]
          },
          "object_name": "4QXH862",
          "has_problems": "yes",
          "tags": ""
        },
        "output": "Machine has got missing disks. "
      }
    ],
    "identifier": 54764031
  },
  {
    "context": [
      "I want to split this file into files dependent on their `type` property: `typea.json`, `typeb.json` etc., each containing their own stream of json objects that only have the matching type property.",
      "cat input.json | jq -c --stream 'select(.[0][0]==\"type\") | .[1]' will return me the values of each of the type properties, but how do I use this to then filter the objects?",
      "jq -j '(.type) + \"\\u0000\" + (. | tojson) + \"\\u0000\"'"
    ],
    "utterance": "Split a stream of objects into separate files, where each file contains only objects with a matching value for the 'type' property.",
    "expressions": [
      "jq -j '(.type) + \"\\u0000\" + (. | tojson) + \"\\u0000\"'"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": "12345",
            "name": "Some name",
            "type": "typea"
          },
          {
            "timestamp": "12345",
            "name": "Some name",
            "type": "typea"
          },
          {
            "timestamp": "12345",
            "name": "Some name",
            "type": "typeb"
          }
        ],
        "output": {
          "typea.json": [
            {
              "timestamp": "12345",
              "name": "Some name",
              "type": "typea"
            },
            {
              "timestamp": "12345",
              "name": "Some name",
              "type": "typea"
            }
          ],
          "typeb.json": [
            {
              "timestamp": "12345",
              "name": "Some name",
              "type": "typeb"
            }
          ]
        }
      }
    ],
    "identifier": 54725080
  },
  {
    "context": [
      "I want to modify the following json using variables specified in a Linux bash shell using jq.",
      "How can I rename a field and set a value for the key from the variables?",
      "jq -n --arg var1 \"$var1\" --arg var2 \"$var2\" --arg var3 \"$var3\" --arg var4 \"$var4\" '\n{\n \"plants\": {\n  \"\\($var2)\": {\n    \"colour\": $var1,\n    \"age\": \"\",\n    \"\\($var3)\": {\n     \"root\": \"\",\n     \"height\": $var4\n    }\n  }\n }\n}'",
      "jq --arg var1 \"$var1\" --arg var2 \"$var2\" --arg var3 \"$var3\" --arg var4 \"$var4\" '\n\n  # set variables for the fields we expect to see in our input\n  \"flowers.small\" as $plant_tmpl |\n  \"vegetables\" as $cat_tmpl |\n\n  # change things inside fields we will later rename *before* we rename those fields\n  .plants[$plant_tmpl].colour = $var1 |\n  .plants[$plant_tmpl][$cat_tmpl].height = $var4 |\n\n  if $var3 == $cat_tmpl then . else\n    # var3 is not \"vegetables\" (templated value), so we need to rename it\n    .plants[$plant_tmpl][$var3] = .plants[$plant_tmpl][$cat_tmpl] |\n    del(.plants[$plant_tmpl][$cat_tmpl])\n  end |\n\n  if $var2 == $plant_tmpl then . else\n    .plants[$var2] = .plants[$plant_tmpl] |\n    del(.plants[$plant_tmpl])\n  end\n' <<'EOF'\n{\n \"plants\": {\n  \"flowers.small\": {\n    \"colour\": \"\",\n    \"age\": \"\",\n    \"vegetables\": {\n     \"root\": \"\",\n     \"height\": \"\"\n    }\n  }\n }\n}\nEOF"
    ],
    "utterance": "Rename object fields and set specific values based on bash variables: change the key 'flowers.small' to the value of var2, the key 'vegetables' to var3, set 'colour' to var1, and 'height' to var4.",
    "expressions": [
      "jq -n --arg var1 \"$var1\" --arg var2 \"$var2\" --arg var3 \"$var3\" --arg var4 \"$var4\" '{\"plants\": { ( $var2 ): { \"colour\": $var1, \"age\": \"\", ( $var3 ): { \"root\": \"\", \"height\": $var4 } } } }'",
      "jq --arg var1 \"$var1\" --arg var2 \"$var2\" --arg var3 \"$var3\" --arg var4 \"$var4\" '\n  \"flowers.small\" as $plant_tmpl |\n  \"vegetables\" as $cat_tmpl |\n  .plants[$plant_tmpl].colour = $var1 |\n  .plants[$plant_tmpl][$cat_tmpl].height = $var4 |\n  if $var3 == $cat_tmpl then . else\n    .plants[$plant_tmpl][$var3] = .plants[$plant_tmpl][$cat_tmpl] |\n    del(.plants[$plant_tmpl][$cat_tmpl])\n  end |\n  if $var2 == $plant_tmpl then . else\n    .plants[$var2] = .plants[$plant_tmpl] |\n    del(.plants[$plant_tmpl])\n  end'"
    ],
    "data": [
      {
        "input": {
          "plants": {
            "flowers.small": {
              "colour": "",
              "age": "",
              "vegetables": {
                "root": "",
                "height": ""
              }
            }
          }
        },
        "output": {
          "plants": {
            "european.flowers": {
              "colour": "red",
              "age": "",
              "european_vegetables": {
                "root": "",
                "height": "20"
              }
            }
          }
        }
      }
    ],
    "identifier": 54601240
  },
  {
    "context": [
      "How can we extract only the titles that contain keywords that are listed in a second \"filter\" array.",
      "The output in this case would be\n[\n  {\"title\": \"second line\"},\n  {\"title\": \"third line\"}\n]",
      "Also, how to use the array filter to negate instead.\nEg: return only the \"first line\" entry in the previous example.",
      "using your shell variable:\n    jq --argjson filter \"$filter\" '\n      map((.title | split(\" \")) as $title\n          | select(any( $title[] as $t\n                        | $filter[] as $kw\n                        | $kw == $t )))' input.json",
      "jq --argjson filter \"$filter\" '\n      map((.title | split(\" \")) as $title\n          | select(all( $title[] as $t\n                        | $filter[] as $kw\n                        | $kw != $t )))' input.json"
    ],
    "utterance": "Select all objects whose title contains at least one word from the filter array; alternatively, select those whose title contains none of the words from the filter array.",
    "expressions": [
      "map((.title | split(\" \")) as $title | select(any($title[] as $t | $filter[] as $kw | $kw == $t)))",
      "map((.title | split(\" \")) as $title | select(all($title[] as $t | $filter[] as $kw | $kw != $t)))"
    ],
    "data": [
      {
        "input": [
          {
            "title": "first line"
          },
          {
            "title": "second line"
          },
          {
            "title": "third line"
          }
        ],
        "output": [
          {
            "title": "second line"
          },
          {
            "title": "third line"
          }
        ]
      }
    ],
    "identifier": 54628953
  },
  {
    "context": [
      "I&#39;m trying to convert this:\r\n\r\n    [\r\n        &quot;arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com&quot;,\r\n        &quot;arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com&quot;,\r\n        &quot;arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com&quot;\r\n    ]\r\n\r\nTo something like this:\r\n\r\n    {\r\n        &quot;0&quot;: &quot;arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com&quot;,\r\n        &quot;1&quot;: &quot;arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com&quot;,\r\n        &quot;2&quot;: &quot;arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com&quot;\r\n    }",
      "Admittedly this is not obvious, but a very short solution is:\r\n\r\n    with_entries(.key |= tostring)",
      "A more pedestrian but still perfectly respectable solution would be:\r\n\r\n    . as $in\r\n    | reduce range(0;length) as $i ({}; . + {($i|tostring): $in[$i]})"
    ],
    "utterance": "Convert an array to an object where each element is assigned to its numeric index as a string key.",
    "expressions": [
      "with_entries(.key |= tostring)",
      ". as $in | reduce range(0;length) as $i ({}; . + {($i|tostring): $in[$i]})"
    ],
    "data": [
      {
        "input": [
          "arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com",
          "arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com",
          "arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com"
        ],
        "output": {
          "0": "arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com",
          "1": "arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com",
          "2": "arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com"
        }
      }
    ],
    "identifier": 54716748
  },
  {
    "context": [
      "Using jq, I need to **get the count** within an array depending on two criterias: it MUST have `status === 'skipped' && ref.includes(version)`",
      "We also like to use environment variable for the query : \n - `status=skipped`\n - `ref=v1.4.15`",
      "This work but without environment variable options:\n    cat test.json | jq '[.[] | select(.status==\"skipped\") | select(.ref | startswith(\"v1.4.15\"))] | length'",
      "status=skipped; ref=v1.4.15; cat test.json | jq --arg REF \"$ref\" --arg STATUS \"$status\" -r '[.[] | select(.status==$STATUS) | select(.ref | startswith($REF))] | length'",
      "jq '[.[] | select(.status == \"skipped\") | select(.ref | test(\"1\\.4\\.15\"))] | length'",
      "ref=\"1\\.4\\.15\"\njq --arg status \"$status\" --arg ref \"$ref\" \\\n    '[.[] | select(.status == $status) | select(.ref | test($ref))]|length' json"
    ],
    "utterance": "Count objects in the array where status equals 'skipped' and ref contains 'v1.4.15', with 'status' and 'ref' provided via command-line arguments.",
    "expressions": [
      "jq --arg REF \"$ref\" --arg STATUS \"$status\" '[.[] | select(.status==$STATUS) | select(.ref | startswith($REF))] | length'",
      "jq --arg status \"$status\" --arg ref \"$ref\" '[.[] | select(.status == $status) | select(.ref | test($ref))] | length'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 15484,
            "sha": "52606c8da57984d1243f436e5d12e275db29a6e0",
            "ref": "v1.4.15",
            "status": "canceled"
          },
          {
            "id": 15483,
            "sha": "52606c8da57984d1243f436e5d12e275db29a6e0",
            "ref": "v1.4.15",
            "status": "canceled"
          },
          {
            "id": 15482,
            "sha": "1b4ccc1dc17e9b8ddb24550c5566d2be6b03465e",
            "ref": "dev",
            "status": "success"
          },
          {
            "id": 15481,
            "sha": "5b6ec939739c5a1513634f3b58bf96522917571d",
            "ref": "dev",
            "status": "failed"
          },
          {
            "id": 15480,
            "sha": "ec18d46f491a4645c68388df91fc41455b421e71",
            "ref": "dev",
            "status": "failed"
          },
          {
            "id": 15479,
            "sha": "dd83a6d6e58cc5114aed8016341ab3c5b3ebb702",
            "ref": "dev",
            "status": "failed"
          },
          {
            "id": 15478,
            "sha": "18ccaf4bc37bf65470b2c6ddaa69e5b4018354a7",
            "ref": "dev",
            "status": "success"
          },
          {
            "id": 15477,
            "sha": "f90900d733bce2be3d9ba9db25f8b51296bc6f3f",
            "ref": "dev",
            "status": "failed"
          },
          {
            "id": 15476,
            "sha": "3cf0431a161e6c9ca90e8248af7b4ec39c54bfb1",
            "ref": "dev",
            "status": "failed"
          },
          {
            "id": 15285,
            "sha": "d24b46edc75d8f7308dbef37d7b27625ef70c845",
            "ref": "dev",
            "status": "success"
          },
          {
            "id": 15265,
            "sha": "52606c8da57984d1243f436e5d12e275db29a6e0",
            "ref": "v1.4.15",
            "status": "success"
          },
          {
            "id": 15264,
            "sha": "9a15f8d4c950047f88c642abda506110b9b0bbd7",
            "ref": "v1.4.15-static",
            "status": "skipped"
          },
          {
            "id": 15263,
            "sha": "9a15f8d4c950047f88c642abda506110b9b0bbd7",
            "ref": "v1.4.15-static",
            "status": "skipped"
          },
          {
            "id": 15262,
            "sha": "76451d2401001c4c51b9800d3cdf62e4cdcc86ba",
            "ref": "v1.4.15-no-js",
            "status": "skipped"
          },
          {
            "id": 15261,
            "sha": "76451d2401001c4c51b9800d3cdf62e4cdcc86ba",
            "ref": "v1.4.15-no-js",
            "status": "skipped"
          },
          {
            "id": 15260,
            "sha": "515cd1b00062e9cbce05420036f5ecc7a898a4bd",
            "ref": "v1.4.15-cli",
            "status": "skipped"
          },
          {
            "id": 15259,
            "sha": "515cd1b00062e9cbce05420036f5ecc7a898a4bd",
            "ref": "v1.4.15-cli",
            "status": "skipped"
          },
          {
            "id": 15258,
            "sha": "b67acd3082da795f022fafc304d267d3afd6b736",
            "ref": "v1.4.15-node",
            "status": "skipped"
          },
          {
            "id": 15257,
            "sha": "b67acd3082da795f022fafc304d267d3afd6b736",
            "ref": "v1.4.15-node",
            "status": "skipped"
          },
          {
            "id": 15256,
            "sha": "4da4a788a85d82527ea568fed4f03da193842a80",
            "ref": "v1.4.15-bs-redux-saga-router-dom-intl",
            "status": "skipped"
          }
        ]
      }
    ],
    "identifier": 54624827
  },
  {
    "context": [
      "I have two files with the following JSON that I need to combine using the relative array position of each object:",
      "PS: - I am restricted to version 1.4 as am on Solaris so don't have the [inputs] feature",
      "the expected result is the elements of input[1] combined with elements of result[1] and so on as follows:",
      "jq --slurp '\n{\n  combined: [\n    .[0].input as $is|\n    .[1].result as $rs|\n    range(0; $is|length) as $n|\n    $is[$n]+$rs[$n]\n  ]\n}\n' file1.json file2.json",
      "$ jq --slurp 'add | reduce range(0; .input | length) as $i (.;\n    .combined += [.input[$i] + .result[$i]]\n) | {combined}' input1.json input2.json"
    ],
    "utterance": "Combine objects at the same array index from the 'input' key in one file and the 'result' key in another file into a new array under the key 'combined'.",
    "expressions": [
      "jq --slurp '{ combined: [.[0].input as $is|.[1].result as $rs|range(0; $is|length) as $n|$is[$n]+$rs[$n]] }' file1.json file2.json",
      "jq --slurp 'add | reduce range(0; .input | length) as $i (.; .combined += [.input[$i] + .result[$i]]) | {combined}' input1.json input2.json"
    ],
    "data": [
      {
        "input": [
          {
            "input": [
              {
                "email": "test1@gm.com",
                "firstName": "Fred"
              },
              {
                "email": "someone@gm.com",
                "firstName": "James"
              }
            ]
          },
          {
            "result": [
              {
                "id": 50,
                "status": "created"
              },
              {
                "id": 51,
                "status": "rejected"
              }
            ]
          }
        ],
        "output": {
          "combined": [
            {
              "email": "test1@gm.com",
              "firstName": "Fred",
              "id": 50,
              "status": "created"
            },
            {
              "email": "someone@gm.com",
              "firstName": "James",
              "id": 51,
              "status": "rejected"
            }
          ]
        }
      }
    ],
    "identifier": 54925675
  },
  {
    "context": [
      "I need to retrieve the list of \"name\".",
      "I have tried with:\n\n    cat jobs.json | jq '.[].name'\n\nIt fails with:\n\n    jq: error (at <stdin>:0): Cannot index string with string \"name\"",
      "found it:\n\n    cat jobs.json | jq '.jobs[].name'"
    ],
    "utterance": "Retrieve all values of the name field from each object in the jobs array at the top level.",
    "expressions": [
      ".jobs[].name"
    ],
    "data": [
      {
        "input": {
          "_class": "model.ListView",
          "jobs": [
            {
              "_class": "hudson.matrix.MatrixProject",
              "name": "tests-different-node-full"
            },
            {
              "_class": "hudson.matrix.MatrixProject",
              "name": "tests-jms-activemq-full"
            },
            {
              "_class": "hudson.matrix.MatrixProject",
              "name": "tests-txpropag-jpa-full"
            }
          ]
        },
        "output": [
          "tests-different-node-full",
          "tests-jms-activemq-full",
          "tests-txpropag-jpa-full"
        ]
      }
    ],
    "identifier": 54710853
  },
  {
    "context": [
      "I\u2019m starting with a JSON file that has multiple objects",
      "and I\u2019m trying to combine those into a single object with the `name` attribute as the key:",
      "Use `reduce` with `inputs`:",
      "jq -n '{ widgets : (reduce inputs as $p ({}; . + ($p | { (.name) : { url } }))) }' file",
      "I'd do it like [this][1]:",
      "jq -s '{ widgets: map( { (.name): {url} } ) | add }'"
    ],
    "utterance": "Combine multiple objects where each object has a name and url into a single object, using the name as the key and mapping its url as the value, all nested under a widgets property.",
    "expressions": [
      "jq -n '{ widgets : (reduce inputs as $p ({}; . + ($p | { (.name) : { url } }))) }'",
      "jq -s '{ widgets: map( { (.name): {url} } ) | add }'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "url": "https://zombo.com"
          },
          {
            "name": "bar",
            "url": "https://acme.com"
          }
        ],
        "output": {
          "widgets": {
            "foo": {
              "url": "https://zombo.com"
            },
            "bar": {
              "url": "https://acme.com"
            }
          }
        }
      }
    ],
    "identifier": 54929491
  },
  {
    "context": [
      "I don&#39;t want to show the elements with the below types. \r\nIf `.ports[].type == \"blackhole\"` or `\"cpu-port\"` or `\"loopback\"`",
      ".ports |= map( select( .type | IN(\"blackhole\", \"cpu-port\", \"loopback\") | not ) )"
    ],
    "utterance": "Remove from the ports array all objects where the type is blackhole, cpu-port, or loopback.",
    "expressions": [
      ".ports |= map(select(.type | IN(\"blackhole\", \"cpu-port\", \"loopback\") | not))",
      ".ports |= map( if .type | IN(\"blackhole\", \"cpu-port\", \"loopback\") then empty else . end)"
    ],
    "data": [
      {
        "input": {
          "uuid": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
          "mp_router_id": "bbbf9a22-5fde-48e2-980f-a6c58d7f941a",
          "config_session_state": "Down",
          "routing_status": "Up",
          "routing_state_flag": 0,
          "vrf_id": 4,
          "routing_state": [],
          "type": "TLR-SR",
          "ports": [
            {
              "uuid": "cc4e8e98-0a22-4534-aa8c-c30c14b5c3a7",
              "urpf-mode": "NONE",
              "ifuid": 284,
              "mac": "02:50:56:56:44:01",
              "lrouter": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
              "admin_up": true,
              "ips": [
                "127.0.0.1/8"
              ],
              "op_state_up": true,
              "owner": "system",
              "type": "loopback",
              "name": "system-loopback-port"
            },
            {
              "uuid": "ee55ef38-941d-5f2e-8ead-c8bf6b1df06d",
              "lrouter": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
              "ifuid": 281,
              "admin_up": true,
              "ips": [],
              "op_state_up": true,
              "type": "cpu-port",
              "name": ""
            },
            {
              "uuid": "8fd5f7a5-5906-40b7-b8c4-877882896ca8",
              "urpf-mode": "NONE",
              "ifuid": 285,
              "mac": "02:50:56:56:53:00",
              "lrouter": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
              "admin_up": false,
              "ips": [
                "169.254.0.2/28"
              ],
              "op_state_up": false,
              "type": "backplane",
              "name": "bp-sr0-port"
            },
            {
              "uuid": "65f526d1-621c-4f5b-a7e6-7d06278e0226",
              "urpf-mode": "NONE",
              "ifuid": 283,
              "mac": "02:50:56:56:44:55",
              "lrouter": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
              "admin_up": false,
              "ips": [
                "100.64.208.1/31"
              ],
              "op_state_up": false,
              "type": "uplink",
              "name": "LinkedPort_t0-uplink"
            },
            {
              "uuid": "36ccfb0d-45ad-5242-9e0f-2898de2c82db",
              "lrouter": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
              "ifuid": 282,
              "admin_up": false,
              "ips": [],
              "op_state_up": false,
              "type": "blackhole",
              "name": ""
            }
          ],
          "vdr_id": 16,
          "name": "SR-t1"
        },
        "output": {
          "uuid": "ce651ed3-78b9-49a0-9d00-9bfaf33bb12c",
          "type": "TLR-SR",
          "ports": [
            {
              "uuid": "8fd5f7a5-5906-40b7-b8c4-877882896ca8",
              "admin_up": false,
              "ips": [
                "169.254.0.2/28"
              ],
              "op_state_up": false,
              "type": "backplane",
              "name": "bp-sr0-port"
            },
            {
              "uuid": "65f526d1-621c-4f5b-a7e6-7d06278e0226",
              "admin_up": false,
              "ips": [
                "100.64.208.1/31"
              ],
              "op_state_up": false,
              "type": "uplink",
              "name": "LinkedPort_t0-uplink"
            }
          ],
          "name": "SR-t1"
        }
      }
    ],
    "identifier": 55133286
  },
  {
    "context": [
      "for commits in $( $repoarray) do curl -i https://api.github.com/repos/$commits/commits | jq -r '.[]|.author.lgoin (and whatever els is needed)' done",
      "- number of commit (ID)",
      "- Date of commit",
      "- Description of commit",
      "- person who commited",
      "- checks passed",
      "- checks failed"
    ],
    "utterance": "Extract from each commit: the commit SHA, commit date, commit message, committer's username, and status check results (passed/failed).",
    "expressions": [
      ".[] | [ .sha, .commit.author.date, .commit.message, .commit.author.name, .author.login ] | @csv",
      ".[] | { id: .sha, date: .commit.author.date, message: .commit.message, committer: .author.login, checks: .status }"
    ],
    "identifier": 54886306
  },
  {
    "context": [
      "I want this type of thing to work",
      "echo '[\"a\",\"b\",\"c\"]' | .\\Downloads\\jq.exe -r '{ \"data\": map({ \"{#SNAME}\": . })}'",
      "But I get an error:",
      "C>echo [\"a\",\"b\",\"c\"] | jq -c \"{\\\"data\\\":map({\\\"{#SNAME}\\\":.})}\"",
      "{ \"data\":[{\"{#SNAME}\":\"a\"},{\"{#SNAME}\":\"b\"},{\"{#SNAME}\":\"c\"}]}",
      "echo '[\"a\", \"b\", \"c\"]' | jq -c '{\"data\": map( {\"SNAME\": . })}'",
      "{ \"data\":[{\"SNAME\":\"a\"},{\"SNAME\":\"b\"},{\"SNAME\":\"c\"}]}"
    ],
    "utterance": "Group the strings in the input array into an object under the key data, mapping each value to a new object with SNAME as the key and the string as the value.",
    "expressions": [
      "{ \"data\": map({ \"SNAME\": . }) }"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": {
          "data": [
            {
              "SNAME": "a"
            },
            {
              "SNAME": "b"
            },
            {
              "SNAME": "c"
            }
          ]
        }
      }
    ],
    "identifier": 54683103
  },
  {
    "context": [
      "I want an array of all the value with key name",
      "One of many possible solutions:\r\n\r\n    [.[] | .name]",
      "result\r\n\r\n    [\"Basement Parking Construction Site 1\",\"Basement Parking Construction Site 2\"]"
    ],
    "utterance": "Get an array containing all values of the key 'name' from each top-level object.",
    "expressions": [
      "[.[] | .name]"
    ],
    "data": [
      {
        "input": {
          "1": {
            "_status_code": 202,
            "_status_message": "Accepted",
            "id": 4120489,
            "parent_id": 0,
            "assigned_to_all": false,
            "billable": false,
            "active": true,
            "type": "regular",
            "has_children": false,
            "billable_rate": 0,
            "short_code": "",
            "name": "Basement Parking Construction Site 1",
            "last_modified": "2019-03-12T10:02:54+00:00",
            "created": "2019-03-12T10:02:54+00:00",
            "filtered_customfielditems": "",
            "required_customfields": [],
            "locations": [],
            "project_id": 0
          },
          "2": {
            "_status_code": 202,
            "_status_message": "Accepted",
            "id": 4120491,
            "parent_id": 0,
            "assigned_to_all": false,
            "billable": false,
            "active": true,
            "type": "regular",
            "has_children": false,
            "billable_rate": 0,
            "short_code": "",
            "name": "Basement Parking Construction Site 2",
            "last_modified": "2019-03-12T10:02:54+00:00",
            "created": "I019-03-12T10:02:54+00:00",
            "filtered_customfielditems": "",
            "required_customfields": [],
            "locations": [],
            "project_id": 0
          }
        },
        "output": [
          "Basement Parking Construction Site 1",
          "Basement Parking Construction Site 2"
        ]
      }
    ],
    "identifier": 55122537
  },
  {
    "context": [
      "Anyone knows how to use jq to sort keys and their array values in json?",
      "jq --sort-keys but it only sorts the keys, but not including their values.",
      "If you are willing to rely on the --sort-keys command-line option to sort the keys, then you can ensure all arrays are sorted by writing:",
      "walk(if type==\"array\" then sort else . end)",
      "If you want the object keys to be sorted internally (i.e. before the final output is generated), then you could augment the above by using the following filter:",
      "walk(if type==\"array\" then sort\n     elif type == \"object\" then to_entries | sort | from_entries\n     else . end)"
    ],
    "utterance": "Sort each array value and the top-level object keys in ascending order.",
    "expressions": [
      "walk(if type==\"array\" then sort else . end)",
      "walk(if type==\"array\" then sort elif type == \"object\" then to_entries | sort | from_entries else . end)"
    ],
    "data": [
      {
        "input": {
          "z": [
            "c",
            "b",
            "a"
          ],
          "y": [
            "e",
            "d",
            "f"
          ],
          "x": [
            "g",
            "i",
            "h"
          ]
        },
        "output": {
          "x": [
            "g",
            "h",
            "i"
          ],
          "y": [
            "d",
            "e",
            "f"
          ],
          "z": [
            "a",
            "b",
            "c"
          ]
        }
      }
    ],
    "identifier": 54678845
  },
  {
    "context": [
      "But I need to get an output with the filesystem Name, so it should be like that:\r\n\r\n    Name1: 1550725120\r\n    Name2: 2390339584",
      "You can use [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)), like this:\r\n\r\n```\r\njq -r \".FileSystems[] | \\\"\\(.Name) \\(.SizeInBytes.Value)\\\"\"\r\n```"
    ],
    "utterance": "List the value of Name and SizeInBytes.Value for each file system in the format: Name: Value",
    "expressions": [
      ".FileSystems[] | \"\\(.Name): \\(.SizeInBytes.Value)\""
    ],
    "data": [
      {
        "input": {
          "FileSystems": [
            {
              "CreationToken": "CreationToken1",
              "OwnerId": "OwnerId1",
              "SizeInBytes": {
                "Timestamp": 1552377599.0,
                "Value": 1550721024
              },
              "Name": "Name1",
              "NumberOfMountTargets": 3,
              "FileSystemId": "fs-1",
              "LifeCycleState": "available",
              "CreationTime": 1550506468.0,
              "PerformanceMode": "generalPurpose"
            },
            {
              "CreationToken": "CreationToken2",
              "OwnerId": "OwnerId2",
              "SizeInBytes": {
                "Timestamp": 1552377599.0,
                "Value": 2390339584
              },
              "Name": "Name2",
              "NumberOfMountTargets": 3,
              "FileSystemId": "fs-2",
              "LifeCycleState": "available",
              "CreationTime": 1547663741.0,
              "PerformanceMode": "generalPurpose"
            }
          ]
        },
        "output": [
          "Name1: 1550721024",
          "Name2: 2390339584"
        ]
      }
    ],
    "identifier": 55118422
  },
  {
    "context": [
      "It has this structure:\r\n\r\n    [\r\n      {\r\n        \"id\": 1,\r\n        \"graphic\": \"filename\",\r\n        \"export_params\": {\r\n          \"uses\": [\r\n            \"string\"\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        \"id\": 2,\r\n        \"graphic\": \"filename2\",\r\n        \"export_params\": []\r\n      },\r\n      ...\r\n    ]",
      "Most objects in this array has full `export_params` info, but sometimes it is just empty array.",
      "I've tried using this jq query\r\n\r\n    .[] | [.id, .graphic, .export_params.uses[], .export_params.export_type ] | @csv\r\n\r\nto turn it into csv, but it broke on a line, where it found first \"empty `export_params`\" key.",
      "But what if `.uses` is an array with more than one item in it?  That would potentially mean a variable number of values\r\nin the rows, which might cause problems.",
      "To restrict consideration to the first item in `.uses`, you could use `first`:\r\n\r\n    .[]\r\n    | [.id,\r\n       .graphic,\r\n       first(.export_params.uses?[] // \"\"), \r\n       (.export_params.export_type? // \"\") ]\r\n    | @csv",
      "To avoid clutter, it might be preferable to tweak the objects before querying them, e.g. along these lines:\r\n\r\n    .[]\r\n    | .export_params |= (if . == [] then {uses: [\"\"]} else . end)\r\n    | [.id, \r\n       .graphic,\r\n       .export_params.uses[0], \r\n       .export_params.export_type ]\r\n    | @csv"
    ],
    "utterance": "Convert an array of objects to CSV, outputting id, graphic, the first uses entry in export_params, and export_type, handling cases where export_params is an empty array.",
    "expressions": [
      ".[] | [.id, .graphic, first(.export_params.uses?[] // \"\"), (.export_params.export_type? // \"\")] | @csv",
      ".[] | .export_params |= (if . == [] then {uses: [\"\"]} else . end) | [.id, .graphic, .export_params.uses[0], .export_params.export_type ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "graphic": "filename",
            "export_params": {
              "uses": [
                "string"
              ]
            }
          },
          {
            "id": 2,
            "graphic": "filename2",
            "export_params": []
          }
        ],
        "output": "\"1\",\"filename\",\"string\",\"\"\n\"2\",\"filename2\",\"\",\"\""
      }
    ],
    "identifier": 54674724
  },
  {
    "context": [
      "Given this input:\n\n```\n{\n    \"source\": {\n        \"items\": [\n            { \"id\": \"aaa\", \"name\": \"this\" },\n            { \"id\": \"bbb\", \"name\": \"that\" },\n            { \"id\": \"ccc\", \"name\": \"the other\" }\n        ]\n    },\n    \"update\": {\n        \"toRemove\": [\n        \t\"aaa\",\n        \t\"ccc\"\n    \t]\n    }\n}\n```",
      "I want this result:\n```\n{\n    \"items\": [\n        { \"id\": \"bbb\", \"name\": \"that\" }\n    ]\n}\n```",
      "This filter does the job but the variables lead me to believe there is a cleaner way.\n\n```\n. as $root | .source + { items: [.source.items[] | select(.id as $id | $root.update.toRemove | contains([$id]) | not)]}\n```",
      "A little shorter version using `inside` instead of `contains`:\n\n    .update.toRemove as $temp |\n     {items: [.source.items[] | select([.id] | inside($temp) | not)]}",
      "Here's a concise and efficient solution:\n\n    .update.toRemove as $rm\n    | .source\n    | .items |= map( select(.id | IN($rm[]) | not))"
    ],
    "utterance": "Return an object with 'items' containing all items from 'source.items' whose 'id' does not appear in 'update.toRemove'.",
    "expressions": [
      ".update.toRemove as $temp | {items: [.source.items[] | select([.id] | inside($temp) | not)]}",
      ".update.toRemove as $rm | .source | .items |= map( select(.id | IN($rm[]) | not))"
    ],
    "data": [
      {
        "input": {
          "source": {
            "items": [
              {
                "id": "aaa",
                "name": "this"
              },
              {
                "id": "bbb",
                "name": "that"
              },
              {
                "id": "ccc",
                "name": "the other"
              }
            ]
          },
          "update": {
            "toRemove": [
              "aaa",
              "ccc"
            ]
          }
        },
        "output": {
          "items": [
            {
              "id": "bbb",
              "name": "that"
            }
          ]
        }
      }
    ],
    "identifier": 55130802
  },
  {
    "context": [
      "I want to build csv in the end looking like this ... which will create an uneven number of columns in the csv.",
      "But I'd like to get this (second line has extra comma after \"significant-influence).",
      "Since you want a rectangular result, you will have to \"pad\" the \"natures_of_control\" array. Based on the sample input, you will need to \"slurp\" the input in order to obtain a global maximum.",
      "To pad the array, you could use the helper function:",
      "def pad($n): range(0;$n) as $i | .[$i];",
      "([.[] | .items[] | .natures_of_control | length] | max) as $mx\n| .[]\n| (.active_count) as $active_count\n| (.ceased_count) as $ceased_count\n| (.links.self | split(\"/\")[2]) as $companyCode\n| .items[]\n| [$companyCode, $active_count, $ceased_count, .name, .country_of_residence, .nationality, .notified_on, (.natures_of_control | pad($mx))]\n| @csv"
    ],
    "utterance": "Produce a CSV where each output row contains the same number of columns, padding the natures_of_control fields for each item so that all rows have the maximum number of natures_of_control values present in any row, filling with nulls or blanks where missing.",
    "expressions": [
      "def pad($n): range(0;$n) as $i | .[$i];\n([.[] | .items[] | .natures_of_control | length] | max) as $mx\n| .[]\n| (.active_count) as $active_count\n| (.ceased_count) as $ceased_count\n| (.links.self | split(\"/\")[2]) as $companyCode\n| .items[]\n| [$companyCode, $active_count, $ceased_count, .name, .country_of_residence, .nationality, .notified_on, (.natures_of_control | pad($mx))]\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "items": [
              {
                "name": "Mr Simon Mackin",
                "country_of_residence": "Scotland",
                "natures_of_control": [
                  "voting-rights-25-to-50-percent-limited-liability-partnership",
                  "significant-influence-or-control-limited-liability-partnership"
                ],
                "premises": "4"
              }
            ]
          },
          {
            "items": [
              {
                "name": "Mrs Simonne Mackinni",
                "country_of_residence": "France",
                "natures_of_control": [
                  "significant-influence-or-control-limited-liability-partnership"
                ],
                "premises": "4"
              }
            ]
          }
        ],
        "output": [
          "\"Mr Simon Mackin\",\"Scotland\",\"voting-rights-25-to-50-percent-limited-liability-partnership\",\"significant-influence-or-control-limited-liability-partnership\",\"4\"",
          "\"Mrs Simonne Mackinni\",\"France\",\"significant-influence-or-control-limited-liability-partnership\",,\"4\""
        ]
      }
    ],
    "identifier": 54943615
  },
  {
    "context": [
      "I need to filter on \"name\" field and print pairs name, url for every name containing \"mail\":",
      "So far this finds all \"name\" that contains \"Mail\", but how do I print \"url\" as well?\n\n    jq -r '.[].name | select(test(\"Mail\";\"i\"))'",
      "Your code selects names whereas you want to select parent objects of names. Following yields your desired output.\n\n    jq -r '.[] | select(.name|test(\"Mail\"; \"i\"))[]' file"
    ],
    "utterance": "Find all objects whose name includes 'Mail' (case-insensitive) and for each, print both the name and url fields on separate lines.",
    "expressions": [
      ".[] | select(.name|test(\"Mail\"; \"i\"))[]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Yahoo",
            "url": "https://www.yahoo.com/"
          },
          {
            "name": "Yahoo Mail",
            "url": "https://mail.yahoo.com/"
          },
          {
            "name": "Google",
            "url": "https://www.google.com/"
          },
          {
            "name": "Google Mail (Gmail)",
            "url": "https://gmail.com/"
          }
        ],
        "output": [
          "Yahoo Mail",
          "https://mail.yahoo.com/",
          "Google Mail (Gmail)",
          "https://gmail.com/"
        ]
      }
    ],
    "identifier": 54489969
  },
  {
    "context": [
      "I have a Ubibot ws-1 and I&#39;m trying to extract Timestamp, Temperature, Humidity, Light and voltage from `last_values` in the following JSON",
      "my jq skills are very poor `.channel.last_values.&quot;\\(.field1)` gives me `jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;null&quot;`.",
      "You need to parse `last_values` as JSON value first. To do that, use `fromjson`:",
      "jq &#39;.channel.last_values|fromjson.field1&#39; file"
    ],
    "utterance": "Extract the Temperature, Humidity, Light, Voltage values and their timestamps from last_values, where last_values is a string-encoded object inside the channel.",
    "expressions": [
      ".channel.last_values | fromjson | {temperature: .field1, humidity: .field2, light: .field3, voltage: .field4}"
    ],
    "data": [
      {
        "input": {
          "channel": {
            "channel_id": "1111",
            "name": "C-1111",
            "field1": "Temperature",
            "field2": "Humidity",
            "field3": "Light",
            "field4": "Voltage",
            "last_values": "{\"field1\":{\"value\":27.186996,\"created_at\":\"2019-02-05T19:12:39Z\"},\"field3\":{\"value\":10.37,\"created_at\":\"2019-02-05T19:12:39Z\"},\"field2\":{\"value\":29,\"created_at\":\"2019-02-05T19:12:39Z\"},\"field5\":{\"value\":-35,\"created_at\":\"2019-02-05T19:12:41Z\"},\"field4\":{\"value\":5,\"created_at\":\"2019-02-05T17:27:38Z\"}}"
          }
        },
        "output": {
          "temperature": {
            "value": 27.186996,
            "created_at": "2019-02-05T19:12:39Z"
          },
          "humidity": {
            "value": 29,
            "created_at": "2019-02-05T19:12:39Z"
          },
          "light": {
            "value": 10.37,
            "created_at": "2019-02-05T19:12:39Z"
          },
          "voltage": {
            "value": 5,
            "created_at": "2019-02-05T17:27:38Z"
          }
        }
      }
    ],
    "identifier": 54546761
  },
  {
    "context": [
      "If you'd like jq to escape dashes, you need to put your key between square brackets like this;\n\n`jq '.[\"key-key\"]'`",
      "apart from that, if you'd like to include a variable in jq, you need to use double quotes instead of single quotes;\n\n`jq \".\"${var[i+1]}\"\"`",
      "but my variable contains dash in it and in this case, I've tried to merge the 2 examples above but it didn't work;",
      "A better way to work with variables in `jq` commands is to define them through the `--arg name value` option, after which you can refer to them with `$foo` *in a single-quotes enclosed command* :\n\n    jq --arg keyName key-key '.[$keyName]'",
      "for searchedKey in \"${var[@]}\"; do\n    echo $json | jq --arg keyName $searchedKey '.[$keyName].something'\ndone"
    ],
    "utterance": "Extract the value of the property named by a shell variable, even if the property name contains a dash.",
    "expressions": [
      "jq --arg keyName \"$searchedKey\" '.[$keyName]'",
      "jq --arg keyName \"$searchedKey\" '.[$keyName].something'"
    ],
    "identifier": 54674527
  },
  {
    "context": [
      "I would need to filter out \"Brisbane\" and \"Perth\" to obtain.",
      "You can use the update assignment operator `|=` in combination with `map`",
      "jq '.cities|=map(if . == \"Brisbane\" or . == \"Perth\" then empty else . end)'",
      "You could use subtraction:",
      "jq '.cities -= [\"Perth\", \"Brisbane\"]'"
    ],
    "utterance": "Remove the entries \"Brisbane\" and \"Perth\" from the cities array inside an object.",
    "expressions": [
      ".cities |= map(if . == \"Brisbane\" or . == \"Perth\" then empty else . end)",
      ".cities -= [\"Perth\", \"Brisbane\"]"
    ],
    "data": [
      {
        "input": {
          "country": "Australia",
          "cities": [
            "Melbourne",
            "Sydney",
            "Brisbane",
            "Perth"
          ]
        },
        "output": {
          "country": "Australia",
          "cities": [
            "Melbourne",
            "Sydney"
          ]
        }
      }
    ],
    "identifier": 54669497
  },
  {
    "context": [
      "I am trying to get the extact format from using jq on the command line ( `jq > file.json`) with subprocess.",
      "But this produces a string instead of the actual formatting of jq. Is there a way for me to obtain the stdout jq on the commandline into a file using python?",
      "p0 = Popen([\"bw\", \"list\", \"--session\", session_key, \"collections\"], stdout=PIPE, check=True)",
      "p1 = Popen([\"jq\", \".\"], stdout=dst, stdin=p0.stdout, check=True)",
      "p1.communicate()"
    ],
    "utterance": "Save command output piped through jq's identity filter exactly as it would appear in a file, using Python subprocess.",
    "expressions": [
      "[\"jq\", \".\"]"
    ],
    "identifier": 54616696
  },
  {
    "context": [
      "I\u2019d like to return a list of services that have the \"build\" key, and not the \"image\" key.",
      "Output should be: [\"web\", \"datadog\"]",
      "jq '.services\n    | . as $services\n    | keys_unsorted\n    | map( select($services[.] | has(\"build\")) )'",
      "jq '.services\n    | to_entries\n    | map( select(.value | has(\"build\")) | .key)'"
    ],
    "utterance": "Return the service names that have a 'build' key and do not have an 'image' key.",
    "expressions": [
      ".services | to_entries | map(select(.value | has(\"build\") and (has(\"image\") | not)) | .key)",
      ".services as $services | keys_unsorted | map(select($services[.] | has(\"build\") and (has(\"image\") | not)))"
    ],
    "data": [
      {
        "input": {
          "version": "3",
          "services": {
            "web": {
              "build": "web"
            },
            "redis": {
              "image": "redis"
            },
            "datadog": {
              "build": "datadog"
            },
            "another": {
              "image": "mysql"
            }
          }
        },
        "output": [
          "web",
          "datadog"
        ]
      }
    ],
    "identifier": 54660692
  },
  {
    "context": [
      "Let&#39;s assume I want all fields, but I want to get rid of that top part that includes `total_items` and `page_count`. So essentially, everything beginning with `landing_id`.",
      "For the given example:\r\n\r\n     jq -c  .items[] lala.json  &gt; lala.jq.json"
    ],
    "utterance": "Extract each object from the 'items' array, omitting the surrounding object with 'total_items' and 'page_count', while retaining all fields of each item.",
    "expressions": [
      ".items[]",
      "-c .items[]"
    ],
    "data": [
      {
        "input": {
          "total_items": 848,
          "page_count": 34,
          "items": [
            {
              "landing_id": "708d9e3eb106820f98162d879198774b",
              "token": "708d9e3eb106820f98162d879198774b",
              "response_id": "708d9e3eb106820f98162d879198774b",
              "landed_at": "2019-02-12T01:58:02Z",
              "submitted_at": "2019-02-12T01:58:31Z",
              "metadata": {
                "user_agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3560.98 Safari/537.36",
                "platform": "other",
                "referer": "https://test.typeform.com/to/LTYE9W?prefilled_answer=8&email=test.x20a@gmail.com",
                "network_id": "35b9eae170",
                "browser": "default"
              },
              "answers": [
                {
                  "field": {
                    "id": "fX64BkjuxYy1",
                    "type": "opinion_scale",
                    "ref": "97f8e18ad06a02e6"
                  },
                  "type": "number",
                  "number": 8
                },
                {
                  "field": {
                    "id": "lYeFxbL67g8B",
                    "type": "multiple_choice",
                    "ref": "78d09e15-7d42-49ec-9f9d-004bf7d3058a"
                  },
                  "type": "choices",
                  "choices": {
                    "labels": [
                      "Experience"
                    ]
                  }
                },
                {
                  "field": {
                    "id": "D3ubKSVfNnlY",
                    "type": "multiple_choice",
                    "ref": "684cb3bd-09cb-4f27-8e7d-baef6a09f787"
                  },
                  "type": "choices",
                  "choices": {
                    "labels": [
                      "Condition"
                    ]
                  }
                },
                {
                  "field": {
                    "id": "UccviSuUQPio",
                    "type": "yes_no",
                    "ref": "ed7e0d9c-5b62-4b0f-9395-54a53d125711"
                  },
                  "type": "boolean",
                  "boolean": false
                }
              ],
              "hidden": {
                "email": "test.x20a@gmail.com"
              }
            }
          ]
        },
        "output": {
          "landing_id": "708d9e3eb106820f98162d879198774b",
          "token": "708d9e3eb106820f98162d879198774b",
          "response_id": "708d9e3eb106820f98162d879198774b",
          "landed_at": "2019-02-12T01:58:02Z",
          "submitted_at": "2019-02-12T01:58:31Z",
          "metadata": {
            "user_agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3560.98 Safari/537.36",
            "platform": "other",
            "referer": "https://test.typeform.com/to/LTYE9W?prefilled_answer=8&email=test.x20a@gmail.com",
            "network_id": "35b9eae170",
            "browser": "default"
          },
          "answers": [
            {
              "field": {
                "id": "fX64BkjuxYy1",
                "type": "opinion_scale",
                "ref": "97f8e18ad06a02e6"
              },
              "type": "number",
              "number": 8
            },
            {
              "field": {
                "id": "lYeFxbL67g8B",
                "type": "multiple_choice",
                "ref": "78d09e15-7d42-49ec-9f9d-004bf7d3058a"
              },
              "type": "choices",
              "choices": {
                "labels": [
                  "Experience"
                ]
              }
            },
            {
              "field": {
                "id": "D3ubKSVfNnlY",
                "type": "multiple_choice",
                "ref": "684cb3bd-09cb-4f27-8e7d-baef6a09f787"
              },
              "type": "choices",
              "choices": {
                "labels": [
                  "Condition"
                ]
              }
            },
            {
              "field": {
                "id": "UccviSuUQPio",
                "type": "yes_no",
                "ref": "ed7e0d9c-5b62-4b0f-9395-54a53d125711"
              },
              "type": "boolean",
              "boolean": false
            }
          ],
          "hidden": {
            "email": "test.x20a@gmail.com"
          }
        }
      }
    ],
    "identifier": 54657231
  },
  {
    "context": [
      "JQ Query:\r\n\r\n\r\n\r\n          .amazon| \r\n          {  \r\n              userType: .userType,\r\n              userName: .user,\r\n              itemCatalog: {   \r\n                 itemId: .items[].id, \r\n                 name: .items[].name  \r\n              }\r\n          }",
      "As already pointed out in a comment, the \"expected response\" is not JSON and probably not what you want anyway.  The following would make sense and in any case illustrates how to iterate appropriately:\r\n\r\n    .amazon\r\n    | { userType: .userType,\r\n        userName: .user,\r\n        itemCatalog: (.items | map({ itemId: .id, name} ))\r\n      }",
      "## Output\r\n\r\n    {\r\n      \"userType\": \"new\",\r\n      \"userName\": \"net\",\r\n      \"itemCatalog\": [\r\n        {\r\n          \"itemId\": 1,\r\n          \"name\": \"harry potter\"\r\n        },\r\n        {\r\n          \"itemId\": 2,\r\n          \"name\": \"adidas shoes\"\r\n        },\r\n        {\r\n          \"itemId\": 3,\r\n          \"name\": \"watch\"\r\n        },\r\n        {\r\n          \"itemId\": 4,\r\n          \"name\": \"adidas shoes\"\r\n        }\r\n      ]\r\n    }"
    ],
    "utterance": "Transform the 'amazon' object to include userType, userName, and an itemCatalog array of objects with itemId and name for each item.",
    "expressions": [
      ".amazon | { userType: .userType, userName: .user, itemCatalog: (.items | map({ itemId: .id, name })) }"
    ],
    "data": [
      {
        "input": {
          "amazon": {
            "activeitem": 2,
            "createdDate": "2019-01-15T17:36:31.588Z",
            "lastModifiedDate": "2019-01-15T17:36:31.588Z",
            "user": "net",
            "userType": "new",
            "items": [
              {
                "id": 1,
                "name": "harry potter",
                "state": "sold",
                "type": {
                  "branded": false,
                  "description": "artwork",
                  "contentLevel": "season"
                }
              },
              {
                "id": 2,
                "name": "adidas shoes",
                "state": "in inventory",
                "type": {
                  "branded": false,
                  "description": "Spprts",
                  "contentLevel": "season"
                }
              },
              {
                "id": 3,
                "name": "watch",
                "state": "returned",
                "type": {
                  "branded": false,
                  "description": "walking",
                  "contentLevel": "special"
                }
              },
              {
                "id": 4,
                "name": "adidas shoes",
                "state": "in inventory",
                "type": {
                  "branded": false,
                  "description": "running",
                  "contentLevel": "winter"
                }
              }
            ],
            "product": {
              "id": 4,
              "name": "adidas shoes",
              "source": "dealer",
              "destination": "resident"
            }
          }
        },
        "output": {
          "userType": "new",
          "userName": "net",
          "itemCatalog": [
            {
              "itemId": 1,
              "name": "harry potter"
            },
            {
              "itemId": 2,
              "name": "adidas shoes"
            },
            {
              "itemId": 3,
              "name": "watch"
            },
            {
              "itemId": 4,
              "name": "adidas shoes"
            }
          ]
        }
      }
    ],
    "identifier": 54642244
  },
  {
    "context": [
      "How can I use bash commands to convert the output of 'kubectl cluster-info dump' into valid json?",
      "I would like to pipe the output of this command through sed or awk to translate this output into valid json, something like:\n\n    [{\"k\",\"v\",\"k2\",\"v2\"},\n     {\"k\",\"v\",\"k2\",\"v2\"},\n     ...\n     {\"k\",\"v\",\"k2\",\"v2\"}]\n\nwhich I can then easily parse with json parsers like jq",
      "Pipe your command's output to [tag:jq]:\n\n    jq -s",
      "If the layout is as shown, then:\n\n    kubectl cluster-info dump |\n    { echo \"[\"; sed -e 's/^}$/},/' -e '$s/^},$/}/'; echo \"]\"; }\n\nwould do the job.",
      "You can avoid the shell `{ \u2026; }` notation with:\n\n    kubectl cluster-info dump |\n    sed -e '1s/^/[/' -e 's/^}$/},/' -e '$s/^},$/}]/'\n\nThe first `sed` commands adds a `[` to the start of the first line; the second changes each line consisting of just `}` to `},` (including the last line), but the third undoes that damage and adds the `]` instead."
    ],
    "utterance": "Combine multiple top-level objects from command output into an array for parsing as a single value.",
    "expressions": [
      "jq -s"
    ],
    "identifier": 54537225
  },
  {
    "context": [
      "I want to join `Reservations` with `Customers` and get something like this:",
      "Here&#39;s a simple solution using `INDEX/2`:",
      "INDEX(.Customers[]; .Id) as $c\n| .Reservations[]\n| { ReservationId: .Id,\n    CustomerName: $c[.CustomerId].Name }",
      "you could use `INDEX/3` as defined below.",
      "def INDEX(s; k; v):\n  reduce s as $x ({}; .[$x|k] = ($x|v));",
      "INDEX(.Customers[]; .Id; .Name) as $c\n| .Reservations[]\n| { ReservationId: .Id,\n    CustomerName: $c[.CustomerId] }"
    ],
    "utterance": "Return all reservations with their reservation ID and the name of the associated customer.",
    "expressions": [
      "INDEX(.Customers[]; .Id) as $c | .Reservations[] | { ReservationId: .Id, CustomerName: $c[.CustomerId].Name }",
      "def INDEX(s; k; v): reduce s as $x ({}; .[$x|k] = ($x|v)); INDEX(.Customers[]; .Id; .Name) as $c | .Reservations[] | { ReservationId: .Id, CustomerName: $c[.CustomerId] }"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Id": "R-1",
              "CustomerId": "1"
            },
            {
              "Id": "R-2",
              "CustomerId": "2"
            }
          ],
          "Customers": [
            {
              "Id": "1",
              "Name": "customer 1"
            },
            {
              "Id": "2",
              "Name": "customer 2"
            },
            {
              "Id": "3",
              "Name": "customer 3"
            }
          ]
        },
        "output": [
          {
            "ReservationId": "R-1",
            "CustomerName": "customer 1"
          },
          {
            "ReservationId": "R-2",
            "CustomerName": "customer 2"
          }
        ]
      }
    ],
    "identifier": 54506913
  },
  {
    "context": [
      "Problem: from a json file, read it up from disk and add a field to a child object and print it back to disk.",
      "However, I need to update the file on disk. So I also need to print the whole object (the parent).",
      "Question: how can I do this so that the `$parent` variable have the new added field, so that I can pipe it back to the original file?",
      "jq '.env_production.abc = \"123\"' pm2.json",
      "< pm2.json jq '.env_production += {\"abc\": \"123\"}'",
      ". + {\"env_production\": (.env_production + {\"abc\":\"123\"})}"
    ],
    "utterance": "Add a field with key 'abc' and value '123' to the 'env_production' child object and output the updated parent object including the change.",
    "expressions": [
      ".env_production.abc = \"123\"",
      ".env_production += {\"abc\": \"123\"}",
      ". + {\"env_production\": (.env_production + {\"abc\":\"123\"})}"
    ],
    "data": [
      {
        "input": {
          "name": "api",
          "script": "index.js",
          "instances": "1",
          "env": {
            "PORT": 3000
          },
          "env_production": {
            "PORT": 3000
          }
        },
        "output": {
          "name": "api",
          "script": "index.js",
          "instances": "1",
          "env": {
            "PORT": 3000
          },
          "env_production": {
            "PORT": 3000,
            "abc": "123"
          }
        }
      }
    ],
    "identifier": 54947468
  },
  {
    "context": [
      "I need to change some of array elements conditionally: if contact_type = email and value like \"yahoo.com\" replace \"yahoo.com\" with \"hotmail.com\".",
      "Here's one of many possible solutions:",
      "walk( if type == \"object\"\n        and .contact_type == \"email\"\n        and (.value | index(\"yahoo.com\"))\n      then .value |= sub(\"yahoo.com\"; \"hotmail.com\")\n      else . end )",
      "def update:\n  if .contact_type == \"email\"\n     and (.value | index(\"yahoo.com\"))\n  then .value |= sub(\"yahoo.com\"; \"hotmail.com\")\n  else . \n  end ;\n\nmap( if .contact_info \n     then .contact_info |= map(update)\n     else .\n     end )"
    ],
    "utterance": "Replace 'yahoo.com' with 'hotmail.com' in the value field of any contact_info object where contact_type is email and the value contains 'yahoo.com'.",
    "expressions": [
      "walk( if type == \"object\" and .contact_type == \"email\" and (.value | index(\"yahoo.com\")) then .value |= sub(\"yahoo.com\"; \"hotmail.com\") else . end )",
      "def update: if .contact_type == \"email\" and (.value | index(\"yahoo.com\")) then .value |= sub(\"yahoo.com\"; \"hotmail.com\") else . end; map( if .contact_info then .contact_info |= map(update) else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "name": "fluffy",
            "type": "cat",
            "contact_info": [
              {
                "contact_type": "phone",
                "value": "123-456-6789"
              },
              {
                "contact_type": "email",
                "value": "fluffy_mean_cat@gmail.com"
              }
            ]
          },
          {
            "name": "breeze",
            "type": "dog",
            "contact_info": [
              {
                "contact_type": "phone",
                "value": "125-856-6789"
              },
              {
                "contact_type": "email",
                "value": "breeze@yahoo.com"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "fluffy",
            "type": "cat",
            "contact_info": [
              {
                "contact_type": "phone",
                "value": "123-456-6789"
              },
              {
                "contact_type": "email",
                "value": "fluffy_mean_cat@gmail.com"
              }
            ]
          },
          {
            "name": "breeze",
            "type": "dog",
            "contact_info": [
              {
                "contact_type": "phone",
                "value": "125-856-6789"
              },
              {
                "contact_type": "email",
                "value": "breeze@hotmail.com"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 55111907
  },
  {
    "context": [
      "Need to fetch exchange rate from the json using jq(within shell script).",
      "Below are the conditions:\r\n    startdate should be eqaul to or greater than current date and enddate should be equal to or less than the current date for given currencyfrom and currencyto.",
      "now as $now\r\n    | map(select(.startdate|secs) <= $now and $now <= (.enddate|secs)) )",
      "def secs: sub(\"\\\\....(?<z>.)$\"; .z) | fromdate;"
    ],
    "utterance": "Select all objects where the current time is between the object's startdate and enddate.",
    "expressions": [
      "def secs: sub(\"\\\\....(?<z>.)$\"; .z) | fromdate; now as $now | map(select((.startdate|secs) <= $now and $now <= (.enddate|secs)))"
    ],
    "data": [
      {
        "input": [
          {
            "status": "ACTIVE",
            "startdate": "2019-01-31T00:00:00.000Z",
            "enddate": "2019-02-07T00:00:00.000Z",
            "source": "default",
            "exchangerate": "12",
            "currencyfrom": "AUD",
            "currencyto": "BRL",
            "id": "64ce2916-af8a-42b9-9fb9-def47f824ea2"
          },
          {
            "status": "ACTIVE",
            "startdate": "2019-03-10T00:00:00.000Z",
            "enddate": "2019-03-30T00:00:00.000Z",
            "source": "default",
            "exchangerate": "13",
            "currencyfrom": "BRL",
            "currencyto": "GBP",
            "id": "4fd0dc10-d6b7-4298-924d-281a0d49c2e9"
          },
          {
            "status": "ACTIVE",
            "startdate": "2019-03-10T00:00:00.000Z",
            "enddate": "2019-03-10T16:20:10.813Z",
            "source": "default",
            "exchangerate": "17",
            "currencyfrom": "AUD",
            "currencyto": "BRL",
            "id": "52bfe481-f4cf-4822-9566-886c4faeaf10"
          }
        ]
      }
    ],
    "identifier": 55101715
  },
  {
    "context": [
      "I want this: { \"level1a\": \"value\", \"level1b\": { \"level2a\": { \"level3a\": \"nestedvalue\" }, \"level2b\": \"value\" } } To end up looking like this: { \"level1a\": \"value\", \"level1b\": { \"level2a.level3a\": \"nestedvalue\", \"level2b\": \"value\" } }",
      "I only want some nested fields to be dotted and I want to be able to choose which fields.",
      "def dotkeys: def stringify: map(tostring) | join(\".\"); . as $in | reduce paths(scalars) as $p (null; ($in|getpath($p)) as $v | setpath([$p|stringify]; $v)); def chain(key): .[key] |= dotkeys ; chain(\"level1b\")"
    ],
    "utterance": "Flatten the nested fields under 'level1b' so nested keys are joined with dots, while leaving other fields untouched.",
    "expressions": [
      "def dotkeys: def stringify: map(tostring) | join(\".\"); . as $in | reduce paths(scalars) as $p (null; ($in|getpath($p)) as $v | setpath([$p|stringify]; $v)); def chain(key): .[key] |= dotkeys ; chain(\"level1b\")"
    ],
    "data": [
      {
        "input": {
          "level1a": "value",
          "level1b": {
            "level2a": {
              "level3a": "nestedvalue"
            },
            "level2b": "value"
          }
        },
        "output": {
          "level1a": "value",
          "level1b": {
            "level2a.level3a": "nestedvalue",
            "level2b": "value"
          }
        }
      }
    ],
    "identifier": 54608267
  },
  {
    "context": [
      "I need the IP output below to be printed in a single line like this \"10.88.4.92\", \"10.88.5.203\", \"10.87.5.215\"",
      "cat ec2.json | jq \".[] | .private_ip\"",
      "\"10.88.4.92\"",
      "\"10.88.5.203\"",
      "\"10.87.5.215\"",
      "How to achieve this with jq",
      "One approach would be to use `@csv`, e.g. along the lines of:",
      "< ec2.json jq -r \"[.[] | .private_ip] | @csv\""
    ],
    "utterance": "Print all values of the .private_ip field as a single comma-separated line, each value in quotes.",
    "expressions": [
      "[.[] | .private_ip] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "private_ip": "10.88.4.92"
          },
          {
            "private_ip": "10.88.5.203"
          },
          {
            "private_ip": "10.87.5.215"
          }
        ],
        "output": "\"10.88.4.92\",\"10.88.5.203\",\"10.87.5.215\""
      }
    ],
    "identifier": 54544077
  },
  {
    "context": [
      "but this is NOT a true .csv file and doesn't work for MS Access or Excel. What I need is output that looks like this....",
      "\"1030907370\",\"en\",3906",
      "Use raw mode (-r)",
      "jq -r '.data | to_entries[] | [.key, .value.client_language, .value.global_rating] | @csv'"
    ],
    "utterance": "Extract account id, client_language, and global_rating as CSV lines suitable for import into MS Access or Excel.",
    "expressions": [
      ".data | to_entries[] | [.key, .value.client_language, .value.global_rating] | @csv"
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "meta": {
            "count": 3
          },
          "data": {
            "1030907370": {
              "client_language": "en",
              "last_battle_time": 1548555418,
              "account_id": 1030907370,
              "created_at": 1525288212,
              "updated_at": 1548557165,
              "private": null,
              "global_rating": 3906,
              "clan_id": null,
              "nickname": "Knightly_Gunner",
              "logout_at": 1548557161
            },
            "1020786770": {
              "client_language": "ja",
              "last_battle_time": 1548948444,
              "account_id": 1020786770,
              "created_at": 1465998341,
              "updated_at": 1548948547,
              "private": null,
              "global_rating": 4396,
              "clan_id": null,
              "nickname": "black_black_boss",
              "logout_at": 1548948544
            },
            "1018984431": {
              "client_language": "en",
              "last_battle_time": 1548550089,
              "account_id": 1018984431,
              "created_at": 1456254986,
              "updated_at": 1548550089,
              "private": null,
              "global_rating": 1666,
              "clan_id": null,
              "nickname": "doctordon",
              "logout_at": 1548550016
            }
          }
        },
        "output": [
          "\"1030907370\",\"en\",3906",
          "\"1020786770\",\"ja\",4396",
          "\"1018984431\",\"en\",1666"
        ]
      }
    ],
    "identifier": 54495664
  },
  {
    "context": [
      "What I would like to get is a csv like this\n\n    OC418979, country_of_residence, officer_role, appointed_on\n    OC418979, country_of_residence, officer_role, appointed_on\n    OC418979, country_of_residence, officer_role, appointed_on\n    OC418979, country_of_residence, officer_role, appointed_on\n    ...",
      "there are 2 types of \"officers\", some are people, some are companies, so not all key in people are present in the other and viceversa. I'd like these entries to be 'null'.",
      "Second complication is those nested objects like \"name\" which contains a comma in it! or address, which contains several sub-objects (which I guess I could flatten in pandas tho).",
      "$ jq -r '(.links.self | split(\"/\")[2]) as $companyCode \n   | .items[]\n   | [ $companyCode, .country_of_residence, .officer_role, .appointed_on ]\n   | @csv\n' input.json"
    ],
    "utterance": "Extract the company number from the links.self path, then for each officer, output a CSV row with the company number, country_of_residence, officer_role, and appointed_on, using null for missing values and handling fields with commas correctly.",
    "expressions": [
      "(.links.self | split(\"/\")[2]) as $companyCode | .items[] | [ $companyCode, .country_of_residence, .officer_role, .appointed_on ] | @csv"
    ],
    "data": [
      {
        "input": {
          "total_results": 13,
          "resigned_count": 9,
          "links": {
            "self": "/company/OC418979/officers"
          },
          "items_per_page": 35,
          "etag": "bc7955679916b089445c9dfb4bc597aa0daaf17d",
          "kind": "officer-list",
          "active_count": 4,
          "inactive_count": 0,
          "start_index": 0,
          "items": [
            {
              "officer_role": "llp-designated-member",
              "name": "BARRICK, David James",
              "date_of_birth": {
                "year": 1984,
                "month": 1
              },
              "appointed_on": "2017-09-15",
              "country_of_residence": "England",
              "address": {
                "country": "United Kingdom",
                "address_line_1": "Old Gloucester Street",
                "locality": "London",
                "premises": "27",
                "postal_code": "WC1N 3AX"
              },
              "links": {
                "officer": {
                  "appointments": "/officers/d_PT9xVxze6rpzYwkN_6b7og9-k/appointments"
                }
              }
            },
            {
              "links": {
                "officer": {
                  "appointments": "/officers/M2Ndc7ZjpyrjzCXdFZyFsykJn-U/appointments"
                }
              },
              "address": {
                "locality": "Tadcaster",
                "country": "United Kingdom",
                "address_line_1": "Westgate",
                "postal_code": "LS24 9AB",
                "premises": "5a"
              },
              "identification": {
                "legal_authority": "UK",
                "identification_type": "non-eea",
                "legal_form": "UK"
              },
              "name": "PREMIER DRIVER LIMITED",
              "officer_role": "corporate-llp-designated-member",
              "appointed_on": "2017-09-15"
            }
          ]
        },
        "output": [
          "\"OC418979\",\"England\",\"llp-designated-member\",\"2017-09-15\"",
          "\"OC418979\",,\"corporate-llp-designated-member\",\"2017-09-15\""
        ]
      }
    ],
    "identifier": 54932167
  },
  {
    "context": [
      "If I want to output\n\n    {\n      \"foo\": {\n        \"name\": \"my foo\"\n      }\n    }",
      "Is there a simpler method to achieve same outcome?",
      "Yes!\n\n    jq '{foo}'\n\n## Explanation\n\n`{foo}` is an abbreviation for `{\"foo\": .foo}`"
    ],
    "utterance": "Extract the 'foo' key and its value from the object, omitting all other keys.",
    "expressions": [
      "{foo}"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "name": "my foo"
          },
          "bar": {
            "name": "my bar"
          }
        },
        "output": {
          "foo": {
            "name": "my foo"
          }
        }
      }
    ],
    "identifier": 55090964
  },
  {
    "context": [
      "I know I can use `tonumber` to convert a string to a number in a simple filter.  However, I cannot figure out how to convert a string to a boolean.",
      "You can use `test` filter to do the check and return true/false.",
      "{\n    happystring: $happystring,\n    unhappynumber1: $unhappynumber1 | tonumber,\n    unhappyboolean: $unhappyboolean | test(\"true\")\n}",
      "There's no need to convert variables to strings like `--arg` does only to convert them back, you can use `--argjson` and still input them separately but with types determined by the normal JSON rules:",
      "jq -n \\\n      --argjson happystring \"$happystring\" \\\n      --argjson unhappynumber1 \"$unhappynumber1\" \\\n      --argjson unhappyboolean \"$unhappyboolean\" \\\n      '{\n          happystring: $happystring,\n          unhappynumber1: $unhappynumber1,\n          unhappyboolean: $unhappyboolean\n      }'"
    ],
    "utterance": "Produce an object with keys happystring (string), unhappynumber1 (number), and unhappyboolean (boolean) sourced from shell variables, converting types as appropriate.",
    "expressions": [
      "{happystring: $happystring, unhappynumber1: $unhappynumber1 | tonumber, unhappyboolean: $unhappyboolean | test(\"true\")}",
      "{happystring: $happystring, unhappynumber1: $unhappynumber1, unhappyboolean: $unhappyboolean}"
    ],
    "data": [
      {
        "input": {
          "happystring": "Bob Ross",
          "unhappynumber1": "1942",
          "unhappyboolean": "true"
        },
        "output": {
          "happystring": "Bob Ross",
          "unhappynumber1": 1942,
          "unhappyboolean": true
        }
      },
      {
        "input": {
          "happystring": "Bob Ross",
          "unhappynumber1": 1942,
          "unhappyboolean": true
        },
        "output": {
          "happystring": "Bob Ross",
          "unhappynumber1": 1942,
          "unhappyboolean": true
        }
      }
    ],
    "identifier": 54814037
  },
  {
    "context": [
      "I want to extract a specific subtree that will be much smaller than the rest, with a known specific key.",
      "How do I extract `subtreeN` with streaming jq?",
      "jq -n -c --arg key \"key2\" --stream -f extract.jq input.json",
      "jq \u2014-stream 'first(fromstream(select(.[0][0]==\"key2\"), [[\"key2\"]]))'"
    ],
    "utterance": "Extract the object with key 'key2' using streaming mode, reconstructing only that subtree.",
    "expressions": [
      "def filter($key): label $out | foreach inputs as $in ( null; if . == null then if $in[0][0] == $key then $in else empty end elif $in[0][0] != $key then break $out else $in end; select(length==2) ); reduce filter($key) as $in ({}; setpath($in[0]; $in[1]) )",
      "first(fromstream(select(.[0][0]==\"key2\"), [[\"key2\"]]))"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "subtree1": {
              "a": {
                "aa": [
                  1,
                  2,
                  3
                ]
              }
            }
          },
          "key2": {
            "subtree2": {
              "b1": {
                "bb": [
                  11,
                  12,
                  13
                ]
              },
              "b2": {
                "bb": [
                  11,
                  12,
                  13
                ]
              }
            }
          },
          "key3": {
            "subtree3": {
              "c": {
                "cc": [
                  21,
                  22,
                  23
                ]
              }
            }
          }
        },
        "output": {
          "key2": {
            "subtree2": {
              "b1": {
                "bb": [
                  11,
                  12,
                  13
                ]
              },
              "b2": {
                "bb": [
                  11,
                  12,
                  13
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 55023433
  },
  {
    "context": [
      "how to make search the result quick to convert to json format can you jq tools or python",
      "such as that out put",
      "[ { \"user\":\"root\",\"host\":\"%\"}, { \"user\":\"test\",\"host\":\"%\"}, ... ]",
      "Here\u2019s an all-jq solution that assumes an invocation like this: jq -Rcn -f program.jq sql.txt",
      "def trim: sub(\" *$\";\"\") | sub(\"^ *\";\"\");",
      "def objectify($headers): . as $in | reduce range(0; $headers|length) as $i ({}; .[$headers[$i]] = ($in[$i]) );",
      "def preprocess: select( startswith(\"|\") ) | split(\"|\") | .[1:-1] | map(trim);",
      "reduce (inputs|preprocess) as $in (null; if . == null then {header: $in} else .header as $h | .table += [$in|objectify($h)] end ) | .table"
    ],
    "utterance": "Convert MySQL table output with columns 'user' and 'host' into an array of objects with keys 'user' and 'host'",
    "expressions": [
      "def trim: sub(\" *$\";\"\") | sub(\"^ *\";\"\");\n\ndef objectify($headers):\n  . as $in\n  | reduce range(0; $headers|length) as $i ({}; .[$headers[$i]] = ($in[$i]) ) ;\n\ndef preprocess:\n  select( startswith(\"|\") )\n  | split(\"|\")\n  | .[1:-1]\n  | map(trim) ;\n\nreduce (inputs|preprocess) as $in (null;\n    if . == null then {header: $in}\n    else .header as $h\n    | .table += [$in|objectify($h)]\n    end )\n  | .table"
    ],
    "data": [
      {
        "input": "+-------------------+-----------+\n| user              | host      |\n+-------------------+-----------+\n| root              | %         |\n| test              | %         |\n| sqlaudit_test_mon | %         |\n| sysbase_test      | %         |\n| mysql.session     | localhost |\n| mysql.sys         | localhost |\n+-------------------+-----------+",
        "output": [
          {
            "user": "root",
            "host": "%"
          },
          {
            "user": "test",
            "host": "%"
          },
          {
            "user": "sqlaudit_test_mon",
            "host": "%"
          },
          {
            "user": "sysbase_test",
            "host": "%"
          },
          {
            "user": "mysql.session",
            "host": "localhost"
          },
          {
            "user": "mysql.sys",
            "host": "localhost"
          }
        ]
      }
    ],
    "identifier": 54867655
  },
  {
    "context": [
      "The response contain a field that contain json data. The response looks like this:",
      "[{\"Status\":\"A\", \"JSON\":\"{\\\"field1\\\":\\\"value1\\\"}\"},{\"Status\":\"B\", \"JSON\":\"{\\\"field1\\\":\\\"value2\\\"}\"}]",
      "`jq` provides a `fromjson` function to parse embedded JSON. For example, \n    $ jq '[].JSON | fromjson | .field1' tmp.json\n    \"value1\"\n    \"value2\""
    ],
    "utterance": "Extract the value of 'field1' from the embedded JSON in the 'JSON' field for each element.",
    "expressions": [
      ".[].JSON | fromjson | .field1"
    ],
    "data": [
      {
        "input": [
          {
            "Status": "A",
            "JSON": "{\"field1\":\"value1\"}"
          },
          {
            "Status": "B",
            "JSON": "{\"field1\":\"value2\"}"
          }
        ],
        "output": [
          "value1",
          "value2"
        ]
      }
    ],
    "identifier": 55029614
  },
  {
    "context": [
      "My aim to to retain the timestamp column, and print the `catId` property:",
      "$ jq -Rr 'split(\"\\t\") | .[1] |= fromjson.catId | join(\"\\t\")' input.log"
    ],
    "utterance": "For each line in tab-separated logs, output the timestamp column and the corresponding catId value from the JSON in the second column.",
    "expressions": [
      "jq -Rr 'split(\"\\t\") | .[1] |= fromjson.catId | join(\"\\t\")'"
    ],
    "data": [
      {
        "input": "2019-02-28T19:43:48.585Z\t{\"id\": 1234, \"catId\": 42, \"img\": \"other.jpg\"}\n2019-02-28T19:44:48.585Z\t{\"id\": 4321, \"catId\": 999, \"img\": \"my.jpg\"}\n2019-02-28T19:44:48.585Z\t{\"id\": 1234, \"catId\": 42, \"img\": \"new.jpg\"}\n2019-02-28T19:46:48.585Z\t{\"id\": 1234, \"catId\": 765, \"img\": \"cat.jpg\"}",
        "output": "2019-02-28T19:43:48.585Z\t42\n2019-02-28T19:44:48.585Z\t999\n2019-02-28T19:44:48.585Z\t42\n2019-02-28T19:46:48.585Z\t765"
      }
    ],
    "identifier": 54933502
  },
  {
    "context": [
      "I can't quite figure out how to transform a JSON file formatted like this:",
      "into this:",
      "I figured out how to use `map()` and `unique` to get the unique combinations of `code`, `latitude`, `longitude` but not how to add the names into an array.",
      "Here's a simple solution using `group_by`:",
      "group_by(.code)\n| map( reduce .[] as $x (.[0] | del(.name); \n         .people += [$x.name]) )",
      "Here's a solution that is more efficient than one using `group_by` in that the latter involves a sort.",
      "Efficiency can be achieved using the builtin `INDEX/1`, and the generic function `aggregate_by` defined as:",
      "def aggregate_by(s; f; g):\n  reduce s as $x  (null; .[$x|f] += [$x|g]);",
      "aggregate_by(.[]; .code; .name) as $dict\n| INDEX(.code)\n| [.[]]\n| map(del(.name) | .person = $dict[.code])"
    ],
    "utterance": "Group objects by code, latitude, and longitude, and produce objects with code, latitude, longitude, and an array of all grouped names.",
    "expressions": [
      "group_by(.code)\n| map( reduce .[] as $x (.[0] | del(.name); .people += [$x.name]) )",
      "def aggregate_by(s; f; g): reduce s as $x (null; .[$x|f] += [$x|g]);\naggregate_by(.[]; .code; .name) as $dict\n| INDEX(.code)\n| [.[]]\n| map(del(.name) | .person = $dict[.code])"
    ],
    "data": [
      {
        "input": [
          {
            "name": "person 1",
            "code": "AAA",
            "latitude": 11,
            "longitude": 22
          },
          {
            "name": "person 2",
            "code": "AAA",
            "latitude": 11,
            "longitude": 22
          },
          {
            "name": "person 3",
            "code": "BBB",
            "latitude": 33,
            "longitude": 44
          },
          {
            "name": "person 4",
            "code": "BBB",
            "latitude": 33,
            "longitude": 44
          }
        ],
        "output": [
          {
            "code": "AAA",
            "latitude": 11,
            "longitude": 22,
            "people": [
              "person 1",
              "person 2"
            ]
          },
          {
            "code": "BBB",
            "latitude": 33,
            "longitude": 44,
            "people": [
              "person 3",
              "person 4"
            ]
          }
        ]
      }
    ],
    "identifier": 55028748
  },
  {
    "context": [
      "Is it possible to retrieve the value of `name` without typing the full path? Something like `jq *.name test.json` with `*` being a wildcard?",
      "One way would be to recurse deep with the `..` to get as deep as possible and _if_ the value is present and _not_ null as",
      "jq '.. | .name? | select(. != null)'"
    ],
    "utterance": "Retrieve all values with key 'name' at any level of nesting.",
    "expressions": [
      ".. | .name? | select(. != null)"
    ],
    "data": [
      {
        "input": {
          "file": {
            "id": "123456789",
            "name": "137.txt"
          },
          "lines": 219,
          "characters": 2456
        },
        "output": "137.txt"
      }
    ],
    "identifier": 55027717
  },
  {
    "context": [
      "How can I select in jq some fields from an array of keys? Not constants, but a list of keys:",
      "$ jq --arg fields 'name,url' '.[$fields | split(\",\")[]]' input.json",
      "jq --argjson keys '[\"a\",\"c\"]' '$keys[] as $key | getpath([$key])'",
      "echo '{\"a\":1,\"b\":2,\"c\":3}' |\r\n  jq --argjson keys '[\"a\",\"c\"]' '$keys[] as $key | getpath([$key])'\r\n1\r\n3"
    ],
    "utterance": "Select the values of fields specified in an array of keys provided at runtime.",
    "expressions": [
      ".[$fields | split(\",\")[]]",
      "$keys[] as $key | getpath([$key])"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3
        },
        "output": [
          1,
          3
        ]
      }
    ],
    "identifier": 55009991
  },
  {
    "context": [
      "I have a list of IPv4 addresses being output in a list each separated by \\n. The program I would like to import these into is expecting it in this format:\r\n\r\n    {\r\n      &quot;data&quot;:[\r\n          { &quot;IP&quot;:&quot;127.0.0.1&quot;  },\r\n          { &quot;IP&quot;:&quot;192.168.0.1&quot; }\r\n      ]\r\n    }",
      "Here is a solution:\r\n\r\n    jq -Rn ' {data: [ {IP: inputs} ] } ' input.txt",
      "jq -Rn ' {data: [ inputs | {IP: .} ] } ' input.txt"
    ],
    "utterance": "Convert a newline-separated list of IPv4 addresses into an object with a key 'data' containing an array of objects each with an 'IP' key set to the address.",
    "expressions": [
      "jq -Rn '{data: [ {IP: inputs} ] }'",
      "jq -Rn '{data: [ inputs | {IP: .} ] }'"
    ],
    "data": [
      {
        "input": "127.0.0.1\n192.168.0.1",
        "output": {
          "data": [
            {
              "IP": "127.0.0.1"
            },
            {
              "IP": "192.168.0.1"
            }
          ]
        }
      }
    ],
    "identifier": 54453131
  },
  {
    "context": [
      "The resulting code should look at the timestamp, determine whether it is unique, and if not, keep the object containing the largest \"count\".",
      "An example of the desired output is below:\n\n    [\n      {\n        \"timestamp\": \"2018-12-24T00:00:00Z\",\n        \"count\": 3,\n        \"uniques\": 2\n      },\n      {\n        \"timestamp\": \"2018-12-25T00:00:00Z\",\n        \"count\": 15,\n        \"uniques\": 9\n      }\n    ]",
      "With these, a solution is the two-liner:\n\n    [ aggregate_by(.[]; .timestamp; .)[]\n      | max_by(.[]; .count) ]"
    ],
    "utterance": "For each timestamp, keep only the object with the largest count.",
    "expressions": [
      "def aggregate_by(s; f; g):\n  reduce s as $x  (null; .[$x|f] += [$x|g]);\n\ndef max_by(s; f):\n  reduce s as $s (null;\n    if . == null then {s: $s, m: ($s|f)}\n    else  ($s|f) as $m\n    | if $m > .m then {s: $s, m: $m} else . end\n    end)\n  | .s ;\n\n[ aggregate_by(.[]; .timestamp; .)[] | max_by(.[]; .count) ]"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": "2018-12-24T00:00:00Z",
            "count": 1,
            "uniques": 1
          },
          {
            "timestamp": "2018-12-24T00:00:00Z",
            "count": 2,
            "uniques": 1
          },
          {
            "timestamp": "2018-12-24T00:00:00Z",
            "count": 3,
            "uniques": 2
          },
          {
            "timestamp": "2018-12-25T00:00:00Z",
            "count": 12,
            "uniques": 5
          },
          {
            "timestamp": "2018-12-25T00:00:00Z",
            "count": 15,
            "uniques": 9
          }
        ],
        "output": [
          {
            "timestamp": "2018-12-24T00:00:00Z",
            "count": 3,
            "uniques": 2
          },
          {
            "timestamp": "2018-12-25T00:00:00Z",
            "count": 15,
            "uniques": 9
          }
        ]
      }
    ],
    "identifier": 55109037
  },
  {
    "context": [
      "Basically I am trying to do a `pick` operation that is dynamic.  My thought process was to do something like this:\n\n```bash\npickJSON() {\n  getSomeJSON | jq -r --arg PICK \"$1\" '{ $PICK }'\n}\n\npickJSON \"foo, bar\"\n```\n\nbut this produces\n\n```\n{ \"PICK\": \"foo, bar\" }\n```\n\nIs there a way to essentially ask it to expand shell-style?",
      "perhaps something like...\n  # getSomeJSON | jq -r --arg PICK \"$1\" '{ ...$PICK }'",
      "getKeysFromSecret() {\n  aws secretsmanager get-secret-value --secret-id \"$1\" \\\n    | jq -r '.SecretString | fromjson' \\\n    | jq -r \"{ $2 }\"\n}",
      "exportVariablesInSecret() {\n  while IFS== read -r key value; do\n    if [ -n \"$value\" ]; then \n      export \"${key}\"=\"${value}\";\n    fi\n  done < <(getKeysFromSecret \"$1\" \"$2\" | jq -r 'to_entries | .[] | .key + \"=\" + .value')\n}"
    ],
    "utterance": "Select a subset of keys specified dynamically as a string from an object, such as picking only 'foo' and 'bar' fields.",
    "expressions": [
      "{ foo, bar }",
      "{ $PICK }"
    ],
    "data": [
      {
        "input": {
          "foo": "foovalue",
          "bar": "barvalue",
          "baz": "bazvalue"
        },
        "output": {
          "foo": "foovalue",
          "bar": "barvalue"
        }
      }
    ],
    "identifier": 55037108
  },
  {
    "context": [
      "I have a bash while do done loop in a loop that outputs using this  \r\n`echo \"${KEY}: {\\\"${ATTRIBUTE}\\\": ${VALUE} }\"`",
      "Input part 1\r\n\r\n    \"PKEY1\": {\"rank\": 1 }\r\n    \"PKEY2\": {\"rank\": 2 }\r\n    \"PKEY3\": {\"rank\": 4 }\r\n    \"PKEY4\": {\"rank\": 3 }",
      "Input part 2\r\n\r\n    \"PKEY1\": {\"attr\": \"xyz\" }\r\n    \"PKEY2\": {\"attr\": \"foo\" }\r\n    \"PKEY3\": {\"attr\": \"bar\" }\r\n    \"PKEY4\": {\"attr\": \"abc\" }",
      "How can I get an output file or echo to look like this in short\r\n\r\n    {\r\n    \"PKEY1\": {\"rank\": 1, \"attr\": \"xyz\" },\r\n    \"PKEY2\": {\"rank\": 2, \"attr\": \"foo\" },\r\n    \"PKEY3\": {\"rank\": 4, \"attr\": \"bar\" },\r\n    \"PKEY4\": {\"rank\": 3, \"attr\": \"abc\" }\r\n    }",
      "If you are using 1.4+ you can use: `jq -s '.[0] * .[1]' file1 file2`",
      "Putting the pieces together, we can write:\r\n\r\n    add_by(inputs | parse; .[0]; .[1])"
    ],
    "utterance": "Merge multiple files containing per-key attribute objects into a single object where each key's entries are combined into one dictionary per key.",
    "expressions": [
      "jq -s '.[0] * .[1]' file1 file2",
      "add_by(inputs | parse; .[0]; .[1])"
    ],
    "data": [
      {
        "input": [
          {
            "PKEY1": {
              "rank": 1
            },
            "PKEY2": {
              "rank": 2
            },
            "PKEY3": {
              "rank": 4
            },
            "PKEY4": {
              "rank": 3
            }
          },
          {
            "PKEY1": {
              "attr": "xyz"
            },
            "PKEY2": {
              "attr": "foo"
            },
            "PKEY3": {
              "attr": "bar"
            },
            "PKEY4": {
              "attr": "abc"
            }
          }
        ],
        "output": {
          "PKEY1": {
            "rank": 1,
            "attr": "xyz"
          },
          "PKEY2": {
            "rank": 2,
            "attr": "foo"
          },
          "PKEY3": {
            "rank": 4,
            "attr": "bar"
          },
          "PKEY4": {
            "rank": 3,
            "attr": "abc"
          }
        }
      }
    ],
    "identifier": 54551554
  },
  {
    "context": [
      "I request the forecast data via the darksky API and format it to csv with `jq` like this",
      "jq '.minutely.data | map([.time, .precipProbability] | join(\",\")) | join(\"\\n\") '",
      "which produces output like this",
      "1552253100,0\n1552253160,0\n1552253220,0\n1552253280,0\n1552253340,0\n1552253400,0.01\n1552253460,0.03\n..."
    ],
    "utterance": "Produce a line for each time and precipitation probability pair from the minutely forecast, formatted as time,precipProbability, one per line.",
    "expressions": [
      ".minutely.data | map([.time, .precipProbability] | join(\",\")) | join(\"\\n\")"
    ],
    "data": [
      {
        "input": {
          "minutely": {
            "data": [
              {
                "time": 1552253100,
                "precipProbability": 0
              },
              {
                "time": 1552253160,
                "precipProbability": 0
              },
              {
                "time": 1552253220,
                "precipProbability": 0
              },
              {
                "time": 1552253280,
                "precipProbability": 0
              },
              {
                "time": 1552253340,
                "precipProbability": 0
              },
              {
                "time": 1552253400,
                "precipProbability": 0.01
              },
              {
                "time": 1552253460,
                "precipProbability": 0.03
              }
            ]
          }
        },
        "output": "1552253100,0\n1552253160,0\n1552253220,0\n1552253280,0\n1552253340,0\n1552253400,0.01\n1552253460,0.03"
      }
    ],
    "identifier": 55092665
  },
  {
    "context": [
      "I'm having trouble passing them in as arguments to jq and scratching my head how to then loop through the 2 arrays within jq itself.",
      "the size of the two below arrays is always equal but not known ahead of time",
      "validSources+=( \"Bitfinex\" \"Poloniex\" \"Coinbase\" )",
      "validPrices+=( \"104.61\" \"102.88\" \"103.96\")",
      "I'm expecting output like this:",
      "{\n   \"assetPair\": \"BTCUSD\",\n   \"version\": \"0.9.1\",\n   \"median\": 103.96,\n   \"medianHex: \"000000000000000000000000000000000000000000000005a2bc1d32419c0000\",\n   \"time\": 1549524531,\n   \"timeHex\": \"000000000000000000000000000000000000000000000000000000005c5bde33\",\n   \"hash\": \"db035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0\",\n   \"signature\": \"51cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b\",\n   \"sources\": {\n      \"Bitfinex\": \"104.61\",\n      \"Coinbase: \"103.96\",\n      \"Poloniex\": \"102.88\"\n   }\n}",
      "I would suggest in your case reading them in separately, e.g. using the technique illustrated by the following:",
      "jq -nc --argjson vs \"$(printf '%s\\n' \"${validSources[@]}\" | jq -nR '[inputs]')\" '$vs'",
      "You can then use $vs and the analogously obtained $vp to construct the object you want as `.sources`, e.g. along the lines of:",
      "[$vs, $vp] | transpose | map({(.[0]): .[1]}) | add"
    ],
    "utterance": "Combine two equally sized arrays, one of source names and one of prices, into an object mapping sources to prices, to be included under a 'sources' key along with other key-value pairs.",
    "expressions": [
      "[$vs, $vp] | transpose | map({(.[0]): .[1]}) | add"
    ],
    "data": [
      {
        "input": {
          "assetPair": "BTCUSD",
          "version": "0.9.1",
          "median": 103.96,
          "medianHex": "000000000000000000000000000000000000000000000005a2bc1d32419c0000",
          "time": 1549524531,
          "timeHex": "000000000000000000000000000000000000000000000000000000005c5bde33",
          "hash": "db035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0",
          "signature": "51cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b",
          "vs": [
            "Bitfinex",
            "Poloniex",
            "Coinbase"
          ],
          "vp": [
            "104.61",
            "102.88",
            "103.96"
          ]
        },
        "output": {
          "assetPair": "BTCUSD",
          "version": "0.9.1",
          "median": 103.96,
          "medianHex": "000000000000000000000000000000000000000000000005a2bc1d32419c0000",
          "time": 1549524531,
          "timeHex": "000000000000000000000000000000000000000000000000000000005c5bde33",
          "hash": "db035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0",
          "signature": "51cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b",
          "sources": {
            "Bitfinex": "104.61",
            "Poloniex": "102.88",
            "Coinbase": "103.96"
          }
        }
      }
    ],
    "identifier": 54586848
  },
  {
    "context": [
      "So for each object name in `.names` update its corresponding object in `.del` ",
      "`[foreach .names[] as $name (.;.del[$name] = false ; .) ] | last`",
      "There is an equivalent reduce:",
      "`reduce .names[] as $name (.; .del[$name]=false)`"
    ],
    "utterance": "Set the value to false for every key in del that matches a name listed in names.",
    "expressions": [
      "reduce .names[] as $name (.; .del[$name]=false)"
    ],
    "data": [
      {
        "input": {
          "names": [
            "a",
            "c"
          ],
          "del": {
            "a": true,
            "b": true,
            "c": true
          }
        },
        "output": {
          "names": [
            "a",
            "c"
          ],
          "del": {
            "a": false,
            "b": true,
            "c": false
          }
        }
      }
    ],
    "identifier": 54842908
  },
  {
    "context": [
      "I need to extract the `lat`, `lon`, and `name` fields, like this:\r\n\r\n    {\r\n      \"lat\": \"49.3877286\",\r\n      \"lon\": \"6.704062\",\r\n      \"name\": \"Beckingen\"\r\n    },\r\n    {\r\n      \"lat\": \"49.287307\",\r\n      \"lon\": \"6.8827786\",\r\n      \"name\": \"P\u00fcttlingen\"\r\n    }",
      "The trick was to use `.tag[]` which multiplies each entry with the number of array elements in `.tag`, then to select the relevant entries and then to construct the output JSON.",
      "{lat: .lat, lon: .lon, tag: .tag[]}\n| select(.tag.k==\"name\") \n| {lat: .lat, lon: .lon, name: .tag.v}"
    ],
    "utterance": "Extract the lat, lon, and the v of the tag whose k is \"name\" for each item in the data.",
    "expressions": [
      "{lat: .lat, lon: .lon, tag: .tag[]} | select(.tag.k==\"name\") | {lat: .lat, lon: .lon, name: .tag.v}"
    ],
    "data": [
      {
        "input": [
          {
            "lat": "49.3877286",
            "lon": "6.704062",
            "tag": [
              {
                "k": "name",
                "v": "Beckingen"
              },
              {
                "k": "is_in",
                "v": "Merzig-Wadern,Saarland,Bundesrepublik Deutschland,Europe"
              },
              {
                "k": "place",
                "v": "town"
              }
            ]
          },
          {
            "lat": "49.287307",
            "lon": "6.8827786",
            "tag": [
              {
                "k": "name",
                "v": "P\u0000ettlingen"
              },
              {
                "k": "place",
                "v": "town"
              },
              {
                "k": "population",
                "v": "18748"
              }
            ]
          }
        ],
        "output": [
          {
            "lat": "49.3877286",
            "lon": "6.704062",
            "name": "Beckingen"
          },
          {
            "lat": "49.287307",
            "lon": "6.8827786",
            "name": "P\u00000ettlingen"
          }
        ]
      }
    ],
    "identifier": 54558107
  },
  {
    "context": [
      "I want to parse the `elbName` directly from the out of the command.",
      "platform json_dump platform_id | jq .elbName",
      "$ echo '{\"elbName\":\"foo\"}' | jq .elbName"
    ],
    "utterance": "Extract the elbName field from the output of the platform json_dump platform_id command, without saving to a file.",
    "expressions": [
      "platform json_dump platform_id | jq .elbName"
    ],
    "data": [
      {
        "input": {
          "elbName": "foo"
        },
        "output": "\"foo\""
      }
    ],
    "identifier": 54480437
  },
  {
    "context": [
      "To protect against the possibility that `.items` is not an array, you could write:\n\n    .items | .[]?\n\nor even more robustly:\n\n    try .items[]\n\nwhich is equivalent to `(.items[])?`.",
      "It is necessary to let JSON know that it can continue after an unexpected value while parsing that array. *try* or *?* are perfect options for that.",
      "Also, it is necessary to be aware about the differences for \"testing\" between ***? vs try***.",
      "**But if you do assume *?* as the same as *try*, you may get an error** (took me a loot to learn this, and it is not clear in the documentation). As an example of improper use of *?* we have:\n\n    jq '{newVar: (.op[].item? // 0)}' <<< $sample\n\nSo, as **op** is **null** it will lead to an error, because you are telling to jq to ignore an error while retrieving *.item*, while there is mention about the possibility of an error during the attempt to iterate over **null** (in this case **.op[]**), and that attempt happened before that point checking for *.item*.\nOn the other hand, **try would work in this case**:\n\n    jq '{newVar: (try .op[].item catch 0)}' <<< $sample"
    ],
    "utterance": "Extract an array of objects with fields landing_id, submitted_at, answers, and email from the items array, even when items may be null.",
    "expressions": [
      ".items | .[]? | {landing_id: .landing_id, submitted_at: .submitted_at, answers: .answers, email: .hidden.email}",
      "try .items[] | {landing_id: .landing_id, submitted_at: .submitted_at, answers: .answers, email: .hidden.email}",
      "(.items[])? | {landing_id: .landing_id, submitted_at: .submitted_at, answers: .answers, email: .hidden.email}"
    ],
    "identifier": 54794749
  },
  {
    "context": [
      "Given a package name, I want to be able to print if its devdependency or dependency and also print the line so that I get the version number.",
      "If I input \"split\": Expected output: > dependencies, \"split\": \"0.3.0\".",
      ".devDependencies[$name] as $v\n    | if $v then \"devDependencies, \\\"\\($name)\\\": \\\"\\($v)\\\"\"\n      else .dependencies[$name] as $v\n      | if $v then \"dependencies, \\\"\\($name)\\\": \\\"\\($v)\\\"\" else empty end\n      end",
      "{devDependencies,dependencies}\n    | map_values(.[$name])\n    | to_entries[]\n    | select(.value)\n    | \"\\(.key), \\\"\\($name)\\\": \\\"\\(.value)\"",
      "(paths | select( .[-1] == $name )) as $p\n    | \"\\($p[-2]), \\\"\\($name)\\\": \\\"\\(getpath($p))\\\"\""
    ],
    "utterance": "Show whether the given package name is a dependency or devDependency, and print its corresponding version line in the format \"type, \\\"name\\\": \\\"version\\\"\".",
    "expressions": [
      ".devDependencies[$name] as $v | if $v then \"devDependencies, \\\"\\($name)\\\": \\\"\\($v)\\\"\" else .dependencies[$name] as $v | if $v then \"dependencies, \\\"\\($name)\\\": \\\"\\($v)\\\"\" else empty end end",
      "{devDependencies,dependencies} | map_values(.[$name]) | to_entries[] | select(.value) | \"\\(.key), \\\"\\($name)\\\": \\\"\\(.value)\"",
      "(paths | select( .[-1] == $name )) as $p | \"\\($p[-2]), \\\"\\($name)\\\": \\\"\\(getpath($p))\\\"\""
    ],
    "data": [
      {
        "input": {
          "name": "universe",
          "devDependencies": {
            "escape-html": "^1.0.3",
            "lucene-query-parser": "^1.0.1"
          },
          "dependencies": {
            "async": "^0.2.10",
            "npm2es": "~0.4.2",
            "optimist": "~0.6.0",
            "request": "~2.30.0",
            "skateboard": "^1.5.1",
            "split": "0.3.0",
            "weld": "^0.2.2"
          }
        },
        "output": "dependencies, \"split\": \"0.3.0\""
      }
    ],
    "identifier": 54619020
  },
  {
    "context": [
      "Here is a very simple example :",
      "echo '{\"array\": [{\"foo\":\"bar\"}]}' | jq -c '.array[] |= try . catch (.)'",
      "output : {\"array\":[{\"__jq\":0}]}",
      "So it would be wrong to use the value, you should perform the assignment within the try expression.",
      "$ echo '{\"array\": [{\"foo\":\"bar\"}]}' | jq -c 'try (.array[] |= .) catch (.)'",
      "You have stumbled upon a bug in jq 1.6. Using jq 1.5, one obtains the correct output:",
      "{\"array\":[{\"foo\":\"bar\"}]}"
    ],
    "utterance": "Update each element of the array and catch errors during the update, returning the original data if any error occurs.",
    "expressions": [
      "try (.array[] |= .) catch (.)"
    ],
    "data": [
      {
        "input": {
          "array": [
            {
              "foo": "bar"
            }
          ]
        },
        "output": {
          "array": [
            {
              "foo": "bar"
            }
          ]
        }
      }
    ],
    "identifier": 54874782
  },
  {
    "context": [
      "Must check \"code\" filed if it's different from 0 to make some actions.",
      "I have to get boolean false or exit 1 to proceed with Bash",
      "you can leverage the `-e` option, that sets the exit status of `jq` based on the query:",
      "echo '{\"code\": 1}' | jq -e '.code == 0'",
      "You can use it to exit by checking the status explicitly",
      "app | jq -e '.code == 0' || exit 1",
      "app | jq -e '.code == 0'; if [ $? -eq 1 ] ; then exit 1; fi"
    ],
    "utterance": "Check if the code field is not 0 and exit with status 1 in Bash if it is.",
    "expressions": [
      ".code == 0"
    ],
    "data": [
      {
        "input": {
          "code": 0,
          "description": "Success",
          "response": {
            "properties": [
              {
                "name": "name",
                "value": "\"cam_src_pipe\"",
                "param": {
                  "description": "The name of the current Gstd session",
                  "type": "gchararray",
                  "access": "((GstdParamFlags) READ | 234)"
                }
              }
            ]
          }
        },
        "output": true
      },
      {
        "input": {
          "code": 1,
          "description": "Failure"
        },
        "output": false
      }
    ],
    "identifier": 54554227
  },
  {
    "context": [
      "What I'm trying to achieve is to add (if not present) or remove (if present) a backend block.",
      "Assuming CI_COMMIT_REF_NAME is available to jq as $CI_COMMIT_REF_NAME...",
      "an appropriate jq filter would be along the following lines:",
      ".spec.rules[0].http.paths |=\n  (map(select(.path | index($CI_COMMIT_REF_NAME) | not)) as $new\n   | if ($new | length) == length\n     then . + [{ \"backend\": { \"serviceName\": $CI_COMMIT_REF_NAME, \"servicePort\": 80}, \"path\": ($CI_COMMIT_REF_NAME + \"/*\") }]\n     else $new\n     end )"
    ],
    "utterance": "Add a backend block with serviceName and path from CI_COMMIT_REF_NAME if not present, or remove it if already present, from .spec.rules[0].http.paths",
    "expressions": [
      ".spec.rules[0].http.paths |=\n  (map(select(.path | index($CI_COMMIT_REF_NAME) | not)) as $new\n   | if ($new | length) == length\n     then . + [{ \"backend\": { \"serviceName\": $CI_COMMIT_REF_NAME, \"servicePort\": 80}, \"path\": ($CI_COMMIT_REF_NAME + \"/*\") }]\n     else $new\n     end )"
    ],
    "identifier": 55108680
  }
]