[
  {
    "context": [
      "I want to join image_files and annotations with condition of annotations.attribute.type == \"letter\".",
      "Expecting following ouptut:",
      "{\n  \"letter_image_files_with_label\": [\n    {\n      \"id\": \"img_0001\",\n      \"width\": 32,\n      \"heigt\": 32,\n      \"file_name\": \"img_0001.png\",\n      \"label\": \"A\"\n    },\n    {\n      \"id\": \"img_0003\",\n      \"width\": 32,\n      \"heigt\": 32,\n      \"file_name\": \"img_0003.png\",\n      \"label\": \"C\"\n    }\n  ]\n}",
      "INDEX(.image_files[]; .id) as $imgs | [\n  .annotations[]\n  | select(.attributes.type == \"letter\")\n  | $imgs[.image_id] + {label: .label}\n]"
    ],
    "utterance": "Produce a list of image file objects, joined with label from annotations where annotation's attributes.type equals \"letter\".",
    "expressions": [
      "INDEX(.image_files[]; .id) as $imgs | {letter_image_files_with_label: [ .annotations[] | select(.attributes.type == \"letter\") | $imgs[.image_id] + {label: .label} ] }"
    ],
    "data": [
      {
        "input": {
          "image_files": [
            {
              "id": "img_0001",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0001.png"
            },
            {
              "id": "img_0002",
              "width": 128,
              "heigt": 32,
              "file_name": "img_0002.png"
            },
            {
              "id": "img_0003",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0003.png"
            },
            {
              "id": "img_0004",
              "width": 160,
              "heigt": 32,
              "file_name": "img_0004.png"
            }
          ],
          "annotations": [
            {
              "id": "ann_0001",
              "image_id": "img_0001",
              "label": "A",
              "attributes": {
                "type": "letter",
                "augmented": false
              }
            },
            {
              "id": "ann_0002",
              "image_id": "img_0002",
              "label": "Good",
              "attributes": {
                "type": "word",
                "augmented": false
              }
            },
            {
              "id": "ann_0003",
              "image_id": "img_0003",
              "label": "C",
              "attributes": {
                "type": "letter",
                "augmented": false
              }
            },
            {
              "id": "ann_0004",
              "image_id": "img_0004",
              "label": "Hello",
              "attributes": {
                "type": "word",
                "augmented": false
              }
            }
          ]
        },
        "output": {
          "letter_image_files_with_label": [
            {
              "id": "img_0001",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0001.png",
              "label": "A"
            },
            {
              "id": "img_0003",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0003.png",
              "label": "C"
            }
          ]
        }
      }
    ],
    "identifier": 60967575
  },
  {
    "context": [
      "I don't care about requests that contain URLs for fonts, CSS, or JavaScript. So, I'd like to remove these requests using `jq`.",
      "How can I create a valid HAR file excluding requests for these certain matching URLs using `jq`?",
      "jq '.log.entries |= ( map ( select ( .request.url | test(\"\\.(js|css|font)\") |not ) ) )'"
    ],
    "utterance": "Exclude from the HAR file all requests with URLs ending in .js, .css, or .font, while preserving the original structure.",
    "expressions": [
      ".log.entries |= ( map ( select ( .request.url | test(\"\\.(js|css|font)\") | not ) ) )"
    ],
    "data": [
      {
        "input": {
          "log": {
            "entries": [
              {
                "request": {
                  "url": "test.css"
                }
              },
              {
                "request": {
                  "url": "test.ok"
                }
              },
              {
                "request": {
                  "url": "test.font"
                }
              },
              {
                "request": {
                  "url": "ok"
                }
              }
            ]
          }
        },
        "output": {
          "log": {
            "entries": [
              {
                "request": {
                  "url": "test.ok"
                }
              },
              {
                "request": {
                  "url": "ok"
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 61057831
  },
  {
    "context": [
      "I want to change the value of a key and print both the changed and original key value.",
      ".ts, (.ts |= strftime(\"%Y-%m-%d %H:%M:%S\") | .ts, .request[])",
      "(.ts | ., strftime(\"%Y-%m-%d %H:%M:%S\")), .request[]"
    ],
    "utterance": "Display the original and formatted 'ts' value followed by all values from the 'request' object.",
    "expressions": [
      ".ts, (.ts |= strftime(\"%Y-%m-%d %H:%M:%S\") | .ts, .request[])",
      "(.ts | ., strftime(\"%Y-%m-%d %H:%M:%S\")), .request[]"
    ],
    "data": [
      {
        "input": {
          "level": "info",
          "ts": 1587565958.8860734,
          "logger": "http.log.access.log0",
          "msg": "handled request",
          "request": {
            "method": "GET",
            "uri": "/info.php",
            "proto": "HTTP/1.1",
            "remote_addr": "192.168.0.92:42170"
          }
        },
        "output": [
          1587565958.8860734,
          "2020-04-22 14:32:38",
          "GET",
          "/info.php",
          "HTTP/1.1",
          "192.168.0.92:42170"
        ]
      }
    ],
    "identifier": 61380661
  },
  {
    "context": [
      "but how I can use them both to get something like this\n\n    [\n      {\n        \"{#IP}\": \"10.234.8.100\",\n        \"{#NAME}\": \"host 1\"\n      },\n      {\n        \"{#IP}\": \"10.234.8.101\",\n        \"{#NAME}\": \"host 2\"\n      },\n      {\n        \"{#IP}\": \"10.234.8.102\",\n        \"{#NAME}\": \"host 3\"\n      }\n    ]",
      "Merge input files side by side using `paste`. Then in JQ, split each line by tab character (`paste`'s default output delimiter), and use resulting parts for building objects.",
      "paste file1 file2 | jq -Rn '[\n  inputs\n  | split(\"\\t\")\n  | {\"{#IP}\": .[0], \"{#NAME}\": .[1]}\n]'",
      "Without `paste` it gets a bit complicated:\n\njq -Rn '[ inputs ]\n| (length / 2) as $i\n| [ .[:$i], .[$i:] ]\n| transpose\n| map({\"{#IP}\": .[0], \"{#NAME}\": .[1]})' file1 file2"
    ],
    "utterance": "Combine each line of the first file with the corresponding line of the second file to produce an array of objects, each containing the keys \"{#IP}\" and \"{#NAME}\" paired from the two files.",
    "expressions": [
      "paste file1 file2 | jq -Rn '[inputs | split(\"\\t\") | {\"{#IP}\": .[0], \"{#NAME}\": .[1]}]'",
      "jq -Rn '[inputs] | (length / 2) as $i | [ .[:$i], .[$i:] ] | transpose | map({\"{#IP}\": .[0], \"{#NAME}\": .[1]})' file1 file2"
    ],
    "data": [
      {
        "input": {
          "file1": [
            "10.10.10.100",
            "10.10.10.101",
            "10.10.10.102"
          ],
          "file2": [
            "host 1",
            "host 2",
            "host 3"
          ]
        },
        "output": [
          {
            "{#IP}": "10.10.10.100",
            "{#NAME}": "host 1"
          },
          {
            "{#IP}": "10.10.10.101",
            "{#NAME}": "host 2"
          },
          {
            "{#IP}": "10.10.10.102",
            "{#NAME}": "host 3"
          }
        ]
      }
    ],
    "identifier": 61225244
  },
  {
    "context": [
      "var=[ { \"Status\": \"ACTIVE\", \"Name\": \"XYZ\", \"JoinedMethod\": \"INVITED\", \"Id\": \"3234443322122\" }, { \"Status\": \"ACTIVE\", \"Name\": \"ABC\", \"JoinedMethod\": \"CREATED\", \"Id\": \"12345678901\" }, { \"Status\": \"ACTIVE\", \"Name\": \"PQR\", \"JoinedMethod\": \"CREATED\", \"Id\": \"3444550998293\" } ]",
      "exception=[\"3444550998293\"]",
      "#then expected result should be:\necho $expected_output\n[\n\"3234443322122\",\n \"12345678901\"\n]",
      "Here is a filter which uses [index/1](https://stedolan.github.io/jq/manual/#index(s),rindex(s)) \nmap( .Id | select( . as $id | $exception | index($id) | not ) )",
      "jq -Mc --argjson exception '[\"3444550998293\"]' -f filter.jq <<< \"${var}\"",
      "Sample output\n[\"3234443322122\",\"12345678901\"]"
    ],
    "utterance": "Select all Id values from a list of accounts except those present in a given exception array.",
    "expressions": [
      "map(.Id | select(. as $id | $exception | index($id) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "Status": "ACTIVE",
            "Name": "XYZ",
            "JoinedMethod": "INVITED",
            "Id": "3234443322122"
          },
          {
            "Status": "ACTIVE",
            "Name": "ABC",
            "JoinedMethod": "CREATED",
            "Id": "12345678901"
          },
          {
            "Status": "ACTIVE",
            "Name": "PQR",
            "JoinedMethod": "CREATED",
            "Id": "3444550998293"
          }
        ],
        "output": [
          "3234443322122",
          "12345678901"
        ]
      }
    ],
    "identifier": 61057336
  },
  {
    "context": [
      "All I want are the unique \"node_ID\" entries overall, I don't care to which object they belong.",
      "With `[.path.mapping[].position.node_id]` I get an array per object, and I can't find any example on how to combine those to use `unique` on them.",
      "Desired output is:\n\n```\n1\n2\n3\n4\n5\n6\n```",
      "$ jq -nr '[inputs.path.mapping[].position.node_id] | unique[]' file"
    ],
    "utterance": "List all unique node_id entries from the mapping arrays across all objects, regardless of which object they belong to.",
    "expressions": [
      "[inputs.path.mapping[].position.node_id] | unique[]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "item1",
            "path": {
              "mapping": [
                {
                  "position": {
                    "node_id": "1"
                  },
                  "rank": "1"
                },
                {
                  "position": {
                    "node_id": "2"
                  },
                  "rank": "2"
                },
                {
                  "position": {
                    "node_id": "3"
                  },
                  "rank": "3"
                },
                {
                  "position": {
                    "node_id": "6"
                  },
                  "rank": "4"
                }
              ]
            }
          },
          {
            "name": "item2",
            "path": {
              "mapping": [
                {
                  "position": {
                    "node_id": "1"
                  },
                  "rank": "1"
                },
                {
                  "position": {
                    "node_id": "5"
                  },
                  "rank": "2"
                },
                {
                  "position": {
                    "node_id": "3"
                  },
                  "rank": "3"
                },
                {
                  "position": {
                    "node_id": "4"
                  },
                  "rank": "4"
                }
              ]
            }
          }
        ],
        "output": [
          "1",
          "2",
          "3",
          "4",
          "5",
          "6"
        ]
      }
    ],
    "identifier": 60930447
  },
  {
    "context": [
      "In order to do this, I would need to flatten the `file` object but different ones represent the nested `error` node as an object or an array. I'm not sure how to flatten it.",
      "Given JQ's `type` builtin, you just need an if-then-else expression to determine if `.file.error` is an array or an object.",
      "```\n.file | map({name} + (.error |\n  if type == \"array\" then .[] else . end))\n```"
    ],
    "utterance": "Flatten a structure containing a list of file objects where each object's 'error' property can be either a single object or an array, producing a flat array of merged name/error objects.",
    "expressions": [
      ".file | map({name} + (.error | if type == \"array\" then .[] else . end))"
    ],
    "data": [
      {
        "input": {
          "version": "6.5",
          "file": [
            {
              "name": "Form/Field/Tokens.php",
              "error": {
                "line": "62",
                "severity": "info",
                "message": "Expected @param annotation",
                "source": "PhanCommentParamOutOfOrder"
              }
            },
            {
              "name": "Console/Command/Reference.php",
              "error": [
                {
                  "line": "40",
                  "severity": "warning",
                  "message": "Possibly zero references to use statement",
                  "source": "PhanUnreferencedUseNormal"
                },
                {
                  "line": "54",
                  "severity": "warning",
                  "message": "Property has undeclared type",
                  "source": "PhanUndeclaredTypeProperty"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "Form/Field/Tokens.php",
            "line": "62",
            "severity": "info",
            "message": "Expected @param annotation",
            "source": "PhanCommentParamOutOfOrder"
          },
          {
            "name": "Console/Command/Reference.php",
            "line": "40",
            "severity": "warning",
            "message": "Possibly zero references to use statement",
            "source": "PhanUnreferencedUseNormal"
          },
          {
            "name": "Console/Command/Reference.php",
            "line": "54",
            "severity": "warning",
            "message": "Property has undeclared type",
            "source": "PhanUndeclaredTypeProperty"
          }
        ]
      }
    ],
    "identifier": 60911346
  },
  {
    "context": [
      "Tried to do it with the following jq command\n\n```map_values(..|{name, id, userStory})```\n\nbut not sure how to filter only the userStory.storyName.",
      "To delete `.id` from root object:\n```\ndel(.id)\n```",
      "To leave only `.storyName` in `.userStory`:\n```\n.userStory |= {storyName}\n```",
      "To delete `.number` and `.level` from every object on any level in `.testSteps`:\n```\n.testSteps |= walk(if type == \"object\" then del(.number, .level) else . end)\n```",
      "Putting it all together:\n```\ndel(.id) | (.userStory |= {storyName}) | (.testSteps |=\n  walk(if type == \"object\" then del(.number, .level) else . end))\n```"
    ],
    "utterance": "Remove the top-level id, keep only storyName inside userStory, and recursively remove number and level from all objects within testSteps.",
    "expressions": [
      "del(.id) | (.userStory |= {storyName}) | (.testSteps |= walk(if type == \"object\" then del(.number, .level) else . end))"
    ],
    "data": [
      {
        "input": {
          "name": "Sample name",
          "id": "123",
          "userStory": {
            "id": "234",
            "storyName": "Story Name",
            "narrative": "Narrative",
            "type": "feature"
          },
          "testSteps": [
            {
              "number": 1,
              "description": "Step 1",
              "level": 0,
              "children": [
                {
                  "number": 2,
                  "description": "Description",
                  "children": [
                    {
                      "number": 3,
                      "description": "Description"
                    }
                  ]
                },
                {
                  "number": 4,
                  "anotherfield": "another field"
                }
              ]
            }
          ]
        },
        "output": {
          "name": "Sample name",
          "userStory": {
            "storyName": "Story Name"
          },
          "testSteps": [
            {
              "description": "Step 1",
              "children": [
                {
                  "description": "Description",
                  "children": [
                    {
                      "description": "Description"
                    }
                  ]
                },
                {
                  "anotherfield": "another field"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 60930293
  },
  {
    "context": [
      "I have been able to get this to work in JQ like below",
      "cat $f | jq 'del(.precondition, .testFailureClassname, .testFailureMessage) >tempfile && mv tempfile $f",
      "jq -s '.' *.json >\"$basedir\"/target/results.json"
    ],
    "utterance": "Remove the keys precondition, testFailureClassname, and testFailureMessage from all objects in each file, then merge all files into a single array.",
    "expressions": [
      "del(.precondition, .testFailureClassname, .testFailureMessage)",
      "-s '.'"
    ],
    "identifier": 60976373
  },
  {
    "context": [
      "I have the below payload, and what I am trying to produce is a horizontal column output like such, with a newline between entries.",
      "JQ doesn&#39;t have a builtin for padding strings but it&#39;s not that hard to implement that functionality. Given `-r/--raw-output` option on the command line, below script will produce your desired output.",
      ".StackEvents\n| map(del(.ResourceProperties))\n| ( [ .[] | keys_unsorted[] ]\n    | map(length)\n    | max + 1\n  ) as $max\n| .[]\n  | ( keys_unsorted as $keys\n    | [ $keys,\n      ( $keys\n        | map(length)\n        | map($max - .)\n        | map(. * \" \" + \": \")\n      ),\n      map(.)\n    ]\n    | transpose[]\n    | add\n  ),\n  \"\"",
      "Here is a solution with some helper functions that can be generalized for other uses.",
      "def width:      map(keys | map(length) | max) | max ;\ndef pad($w):    . + (($w-length)*\" \") ;\n\n  .StackEvents\n| width as $w\n| map(del(.ResourceProperties) | to_entries | map(\"\\(.key|pad($w)) : \\(.value)\"), [\"\"])\n| .[][]",
      "Here is version with those improvements:\ndef width:      map(keys_unsorted | map(length) | max) | max ;\ndef pad($w):    . + (($w-length)*\" \") ;\n\n  .StackEvents\n| map(del(.ResourceProperties))\n| width as $w\n| map(to_entries | map(\"\\(.key|pad($w)) : \\(.value)\"), [\"\"])\n| .[][]",
      "def max(stream):\n  reduce stream as $x (null; if . == null then $x elif $x > . then $x else . end);\n\ndef grapheme_length:\n  gsub(\"\\\\p{Mn}\";\"\") | gsub(\"\\\\p{Mc}\";\"\") | gsub(\"\\\\p{Cf}\";\"\")\n  | length;\n\ndef pad($w): tostring + (($w - grapheme_length)*\" \") ;",
      ".StackEvents\n| max(.[]\n      | keys_unsorted[] \n      | select(. != \"ResourceProperties\") \n      | grapheme_length) as $w\n| map(del(.ResourceProperties)\n      | to_entries\n      | map(\"\\(.key|pad($w)) : \\(.value)\"), [\"\"])\n| .[][]"
    ],
    "utterance": "Produce a vertically aligned table output listing each event's key and value on its own line, column-justified to the maximum key width, omitting the ResourceProperties field, with a blank line between records.",
    "expressions": [
      ".StackEvents\n| map(del(.ResourceProperties))\n| ( [ .[] | keys_unsorted[] ]\n    | map(length)\n    | max + 1\n  ) as $max\n| .[]\n  | ( keys_unsorted as $keys\n    | [ $keys,\n      ( $keys\n        | map(length)\n        | map($max - .)\n        | map(. * \" \" + \": \")\n      ),\n      map(.)\n    ]\n    | transpose[]\n    | add\n  ),\n  \"\"",
      "def width:      map(keys_unsorted | map(length) | max) | max ;\ndef pad($w):    . + (($w-length)*\" \") ;\n\n  .StackEvents\n| map(del(.ResourceProperties))\n| width as $w\n| map(to_entries | map(\"\\(.key|pad($w)) : \\(.value)\"), [\"\"])\n| .[][]",
      "def max(stream):\n  reduce stream as $x (null; if . == null then $x elif $x > . then $x else . end);\n\ndef grapheme_length:\n  gsub(\"\\\\p{Mn}\";\"\") | gsub(\"\\\\p{Mc}\";\"\") | gsub(\"\\\\p{Cf}\";\"\")\n  | length;\n\ndef pad($w): tostring + (($w - grapheme_length)*\" \") ;\n\n.StackEvents\n| max(.[]\n      | keys_unsorted[] \n      | select(. != \"ResourceProperties\") \n      | grapheme_length) as $w\n| map(del(.ResourceProperties)\n      | to_entries\n      | map(\"\\(.key|pad($w)) : \\(.value)\"), [\"\"])\n| .[][]"
    ],
    "data": [
      {
        "input": {
          "StackEvents": [
            {
              "StackId": "arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983",
              "EventId": "BBWebhookLogGroup-CREATE_IN_PROGRESS-2020-04-03T12:06:51.884Z",
              "StackName": "cbongiorno-30800-bb-lambda",
              "LogicalResourceId": "BBWebhookLogGroup",
              "PhysicalResourceId": "cbongiorno-30800-bb-lambda",
              "ResourceType": "AWS::Logs::LogGroup",
              "Timestamp": "2020-04-03T12:06:51.884Z",
              "ResourceStatus": "CREATE_IN_PROGRESS",
              "ResourceStatusReason": "Resource creation Initiated",
              "ResourceProperties": "{\"RetentionInDays\":\"7\",\"LogGroupName\":\"cbongiorno-30800-bb-lambda\"}"
            },
            {
              "StackId": "arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983",
              "EventId": "BBUserName-CREATE_IN_PROGRESS-2020-04-03T12:06:51.509Z",
              "StackName": "cbongiorno-30800-bb-lambda",
              "LogicalResourceId": "BBUserName",
              "PhysicalResourceId": "",
              "ResourceType": "AWS::SSM::Parameter",
              "Timestamp": "2020-04-03T12:06:51.509Z",
              "ResourceStatus": "CREATE_IN_PROGRESS",
              "ResourceProperties": "{\"Type\":\"String\",\"Description\":\"The username for this lambda to operate under\",\"Value\":\"chb0bitbucket\",\"Name\":\"/bb-webhooks/authorization/username\"}"
            }
          ]
        },
        "output": [
          "StackId              : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983",
          "EventId              : BBWebhookLogGroup-CREATE_IN_PROGRESS-2020-04-03T12:06:51.884Z",
          "StackName            : cbongiorno-30800-bb-lambda",
          "LogicalResourceId    : BBWebhookLogGroup",
          "PhysicalResourceId   : cbongiorno-30800-bb-lambda",
          "ResourceType         : AWS::Logs::LogGroup",
          "Timestamp            : 2020-04-03T12:06:51.884Z",
          "ResourceStatus       : CREATE_IN_PROGRESS",
          "ResourceStatusReason : Resource creation Initiated",
          "",
          "StackId              : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983",
          "EventId              : BBUserName-CREATE_IN_PROGRESS-2020-04-03T12:06:51.509Z",
          "StackName            : cbongiorno-30800-bb-lambda",
          "LogicalResourceId    : BBUserName",
          "PhysicalResourceId   : ",
          "ResourceType         : AWS::SSM::Parameter",
          "Timestamp            : 2020-04-03T12:06:51.509Z",
          "ResourceStatus       : CREATE_IN_PROGRESS",
          ""
        ]
      }
    ],
    "identifier": 61056651
  },
  {
    "context": [
      "if (name == 'ford')(name can be a variable) I want to get the all the versions whose `count != 3` and if all the version's `count == 3` I want to get the RealVersion of ford so in this case output should be. EXPECTED OUTPUT = [122 144 ]",
      "Now in this case all the version's count == 3 so now I want to get the real version which is 155 EXPECTED OUTPUT SHOULD BE 155",
      "I am using this command cat demo | jq  '.RealVersion as $RealVersion | select(.name == \"bmw\") | .availableVersions |  map(select(.count != 3)) |  if length > 0 then map(.version) else $RealVersion end' which worked fine but it is returning a json array if there is more than one element. But i want to store it in a normal array.",
      "Using `join` and then a string concatenation at the end to add the brackets ...",
      "jq --compact-output --raw-output '.RealVersion as $RealVersion | select(.name == \"ford\") | .availableVersions | map(select(.count != 3)) | if length > 0 then map(.version) else $RealVersion end | join (\" \") | \"[\" + . + \"]\"'",
      "[122 144]"
    ],
    "utterance": "For a given car name, output all version numbers where count is not 3 as a space-separated list in brackets; if all counts are 3, output RealVersion as a scalar.",
    "expressions": [
      ".RealVersion as $RealVersion | select(.name == \"ford\") | .availableVersions | map(select(.count != 3)) | if length > 0 then map(.version) else $RealVersion end | join (\" \") | \"[\" + . + \"]\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 2
              },
              {
                "version": 133,
                "count": 3
              },
              {
                "version": 144,
                "count": 1
              }
            ],
            "RealVersion": 155
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 244,
                "count": 1
              },
              {
                "version": 255,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": "[122 144]"
      },
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 3
              },
              {
                "version": 133,
                "count": 3
              },
              {
                "version": 144,
                "count": 3
              }
            ],
            "RealVersion": 155
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 244,
                "count": 1
              },
              {
                "version": 255,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": "155"
      }
    ],
    "identifier": 61223890
  },
  {
    "context": [
      "I\u2019d like to filter logs that has either `level==\"info\"` or `msg==\"end\"`, so the query should select the first log and the last log line:",
      "I tried `jq 'select(.level=\"info\") || select(.msg=\"end\")'` but doesn't work.",
      "Use the `or` keyword.",
      "select(.level == \"info\" or .msg == \"end\")"
    ],
    "utterance": "Select log objects where level is equal to \"info\" or msg is equal to \"end\".",
    "expressions": [
      "select(.level == \"info\" or .msg == \"end\")"
    ],
    "data": [
      {
        "input": [
          {
            "level": "info",
            "value": 3
          },
          {
            "level": "debug",
            "msg": "start"
          },
          {
            "level": "debug",
            "msg": "end"
          }
        ],
        "output": [
          {
            "level": "info",
            "value": 3
          },
          {
            "level": "debug",
            "msg": "end"
          }
        ]
      }
    ],
    "identifier": 61443708
  },
  {
    "context": [
      "You could try preserving the quotes around CLOSED by changing:",
      "assertEqual &quot;CLOSED&quot; &quot;$($EXEC wget movie-composite:8080/actuator/health -qO - | jq .components.movieCircuitBreaker.details.state)&quot; &quot;Verify that circuit breaker has status CLOSED&quot;",
      "jq outputs well-formed JSON by default, so strings will be quoted.",
      "You could quote the expected string, as @rtx13 suggests, but I think it's clearer to have jq output just the contents of the field. You can do that with the --raw-output flag:",
      "$ jq -r .foo <<<'{\"foo\":\"bar\"}'"
    ],
    "utterance": "Extract the value of the components.movieCircuitBreaker.details.state field as an unquoted string.",
    "expressions": [
      ".components.movieCircuitBreaker.details.state | @text",
      "-r .components.movieCircuitBreaker.details.state"
    ],
    "data": [
      {
        "input": {
          "components": {
            "movieCircuitBreaker": {
              "details": {
                "state": "CLOSED"
              }
            }
          }
        },
        "output": "CLOSED"
      }
    ],
    "identifier": 61053995
  },
  {
    "context": [
      "if (name == 'ford')(name can be a variable) I want to get the all the versions whose `count != 3`",
      "and if all the version's `count == 3` I want to get the RealVersion of ford so in this case output should be.",
      "EXPECTED OUTPUT = [122 144 ]",
      "Now if all the version count ==3 ... now I want to get the real version which is 155",
      "EXPECTED OUTPUT SHOULD BE 155",
      "The following program, when invoked with the -n command-line option, produces the expected output in both cases:",
      "inputs\n| .RealVersion as $RealVersion\n| select(.name == \"ford\")\n| .availableVersions\n| map(select(.count != 3))\n| if length > 0 then map(.version)\n  else $RealVersion\n  end"
    ],
    "utterance": "For the item with name equal to ford, if any availableVersions have count not equal to 3, output their version values; otherwise, output RealVersion.",
    "expressions": [
      "inputs | .RealVersion as $RealVersion | select(.name == \"ford\") | .availableVersions | map(select(.count != 3)) | if length > 0 then map(.version) else $RealVersion end"
    ],
    "data": [
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 2
              },
              {
                "version": 133,
                "count": 3
              },
              {
                "version": 144,
                "count": 1
              }
            ],
            "RealVersion": 155
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 244,
                "count": 1
              },
              {
                "version": 255,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": [
          122,
          144
        ]
      },
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 3
              },
              {
                "version": 133,
                "count": 3
              },
              {
                "version": 144,
                "count": 3
              }
            ],
            "RealVersion": 155
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 244,
                "count": 1
              },
              {
                "version": 255,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": 155
      }
    ],
    "identifier": 61216427
  },
  {
    "context": [
      "I am trying to read the CIDR blocks from the VPCs in AWS on the AWS CLI. I will use this in a script when I&#39;m done. I am using `jq` to parse the info:",
      "However, `jq` only returns one of the two CIDR blocks in the VPC.",
      "I need to get all VPC CIDR blocks in the output.",
      "You have two keys `CidrBlock` and `CidrBlockAssociationSet` under the `Vpcs` array.",
      "aws ec2 describe-vpcs --region=us-east-1 |\n  jq -r '.Vpcs[] | .CidrBlock, .CidrBlockAssociationSet[].CidrBlock'",
      "and this is an invariant solution:\n\naws ... | jq -r '.. | if type == \"object\" and has(\"CidrBlock\") then .CidrBlock else empty end'",
      "and, inspired by [jq170727's answer](https://stackoverflow.com/a/61047163/11385808), a less expressive form:\naws ... | jq -r '.. | objects | .CidrBlock // empty'",
      "Here is a filter inspired by [Dmitry's answer](https://stackoverflow.com/a/61046815/8379597) which is slightly shorter: `.. | .CidrBlock? | values`"
    ],
    "utterance": "Extract all values of CidrBlock, including both direct VPC blocks and those in CidrBlockAssociationSet, from the AWS VPCs describe CLI output.",
    "expressions": [
      ".Vpcs[] | .CidrBlock, .CidrBlockAssociationSet[].CidrBlock",
      ".. | if type == \"object\" and has(\"CidrBlock\") then .CidrBlock else empty end",
      ".. | objects | .CidrBlock // empty",
      ".. | .CidrBlock? | values"
    ],
    "data": [
      {
        "input": {
          "Vpcs": [
            {
              "CidrBlock": "10.200.3.0/24",
              "DhcpOptionsId": "dopt-d0aa95ab",
              "State": "available",
              "VpcId": "vpc-00de11103235ec567",
              "OwnerId": "046480487130",
              "InstanceTenancy": "default",
              "Ipv6CidrBlockAssociationSet": [
                {
                  "AssociationId": "vpc-cidr-assoc-09f19d81c2e4566b9",
                  "Ipv6CidrBlock": "2600:1f18:1f7:300::/56",
                  "Ipv6CidrBlockState": {
                    "State": "associated"
                  },
                  "NetworkBorderGroup": "us-east-1"
                }
              ],
              "CidrBlockAssociationSet": [
                {
                  "AssociationId": "vpc-cidr-assoc-0511a5d459f937899",
                  "CidrBlock": "10.238.3.0/24",
                  "CidrBlockState": {
                    "State": "associated"
                  }
                },
                {
                  "AssociationId": "vpc-cidr-assoc-05ad73e8c515a470f",
                  "CidrBlock": "100.140.0.0/27",
                  "CidrBlockState": {
                    "State": "associated"
                  }
                }
              ],
              "IsDefault": false,
              "Tags": [
                {
                  "Key": "environment",
                  "Value": "int01"
                },
                {
                  "Key": "Name",
                  "Value": "company-int01-vpc"
                },
                {
                  "Key": "project",
                  "Value": "company"
                }
              ]
            }
          ]
        },
        "output": [
          "10.200.3.0/24",
          "10.238.3.0/24",
          "100.140.0.0/27"
        ]
      }
    ],
    "identifier": 61046528
  },
  {
    "context": [
      "But what I am really looking for is to have the current time-stamp included the json body, something as if:        { \"current-time\": \"Wed Apr 15 14:18:42 PDT 2020\", \"online\": 85, \"offline\": 196 }",
      "jq has the `now` builtin:\n```\nTZ=UTC jq -n 'now | strftime(\"%a %b %d, %Y %Z %H:%M:%S\")'\n\"Wed Apr 15, 2020 UTC 21:51:07\"\n```",
      "It should be possible to pass the result of another command (or a variable etc) to the jq command.\n\nIf in bash, something like the following could work:\n\n    curl ..... | jq -c --arg datum \"$(date)\" '{\"online\": .switches.optional.online, \"offline\": .switches.optional.offline, \"current-time\": $datum}'"
    ],
    "utterance": "Add the current timestamp as a new field in the output, along with the values of .switches.optional.online and .switches.optional.offline.",
    "expressions": [
      "jq -c --arg datum \"$(date)\" '{\"online\": .switches.optional.online, \"offline\": .switches.optional.offline, \"current-time\": $datum}'",
      "jq --arg now \"$(date)\" '{\"current-time\": $now, \"online\": .switches.optional.online, \"offline\": .switches.optional.offline}'",
      "jq '. + {\"current-time\": (now | strflocaltime(\"%a %b %d %H:%M:%S %Z %Y\"))}'"
    ],
    "data": [
      {
        "input": {
          "switches": {
            "optional": {
              "online": 85,
              "offline": 196
            }
          }
        },
        "output": {
          "current-time": "Wed Apr 15 22:03:00 UTC 2020",
          "online": 85,
          "offline": 196
        }
      }
    ],
    "identifier": 61238933
  },
  {
    "context": [
      "Is there any way to get \"empty\" values?",
      "Is there any way to produce second output with jq with out needing to iterate on bash?",
      "Get product names using `keys_unsorted` (which necessitates deleting `date`) and use an `if-then-else` expression for alternating an empty `interval` with `[{\"time\": \"N/A\", \"price\": -1}]`.",
      "```\n.[]\n| {date} + (\n  del(.date)\n  | keys_unsorted[] as $product\n  | {$product} + (\n    .[$product].interval\n    | if . == [] then\n        {time: \"N/A\", price: -1}\n      else\n        .[]\n      end\n  )\n)\n```"
    ],
    "utterance": "Flatten objects by date and product name, including 'time' and 'price', and for products with empty intervals output an entry with time \"N/A\" and price -1.",
    "expressions": [
      ".[]\n| {date} + (\n  del(.date)\n  | keys_unsorted[] as $product\n  | {product: $product} + (\n    .[$product].interval \n    | if . == [] then\n        {time: \"N/A\", price: -1}\n      else\n        .[]\n      end\n  )\n)"
    ],
    "data": [
      {
        "input": [
          {
            "date": "2020-04-13",
            "product1": {
              "p_max": 18.0,
              "p_min": 8.0,
              "interval": [
                {
                  "time": "06:00:00",
                  "price": 8.0
                },
                {
                  "time": "12:00:00",
                  "price": 18.0
                },
                {
                  "time": "18:00:00",
                  "price": 16.0
                },
                {
                  "time": "24:00:00",
                  "price": 9.0
                }
              ]
            },
            "product2": {
              "p_max": 18.0,
              "p_min": 8.0,
              "interval": [
                {
                  "time": "06:00:00",
                  "price": 8.0
                },
                {
                  "time": "12:00:00",
                  "price": 18.0
                },
                {
                  "time": "18:00:00",
                  "price": 16.0
                },
                {
                  "time": "24:00:00",
                  "price": 9.0
                }
              ]
            }
          },
          {
            "date": "2020-04-14",
            "product1": {
              "p_max": 18.0,
              "p_min": 8.0,
              "interval": [
                {
                  "time": "06:00:00",
                  "price": 8.0
                },
                {
                  "time": "12:00:00",
                  "price": 18.0
                },
                {
                  "time": "18:00:00",
                  "price": 16.0
                },
                {
                  "time": "24:00:00",
                  "price": 9.0
                }
              ]
            },
            "product2": {
              "p_max": 18.0,
              "p_min": 8.0,
              "interval": [
                {
                  "time": "06:00:00",
                  "price": 9.0
                },
                {
                  "time": "12:00:00",
                  "price": 16.0
                },
                {
                  "time": "18:00:00",
                  "price": 15.0
                },
                {
                  "time": "24:00:00",
                  "price": 11.0
                }
              ]
            }
          },
          {
            "date": "2020-04-15",
            "product1": {
              "p_max": 16.0,
              "p_min": 9.0,
              "interval": []
            },
            "product2": {
              "p_max": 16.0,
              "p_min": 9.0,
              "interval": []
            }
          }
        ],
        "output": [
          {
            "date": "2020-04-13",
            "product": "product1",
            "time": "06:00:00",
            "price": 8.0
          },
          {
            "date": "2020-04-13",
            "product": "product1",
            "time": "12:00:00",
            "price": 18.0
          },
          {
            "date": "2020-04-13",
            "product": "product1",
            "time": "18:00:00",
            "price": 16.0
          },
          {
            "date": "2020-04-13",
            "product": "product1",
            "time": "24:00:00",
            "price": 9.0
          },
          {
            "date": "2020-04-13",
            "product": "product2",
            "time": "06:00:00",
            "price": 8.0
          },
          {
            "date": "2020-04-13",
            "product": "product2",
            "time": "12:00:00",
            "price": 18.0
          },
          {
            "date": "2020-04-13",
            "product": "product2",
            "time": "18:00:00",
            "price": 16.0
          },
          {
            "date": "2020-04-13",
            "product": "product2",
            "time": "24:00:00",
            "price": 9.0
          },
          {
            "date": "2020-04-14",
            "product": "product1",
            "time": "06:00:00",
            "price": 8.0
          },
          {
            "date": "2020-04-14",
            "product": "product1",
            "time": "12:00:00",
            "price": 18.0
          },
          {
            "date": "2020-04-14",
            "product": "product1",
            "time": "18:00:00",
            "price": 16.0
          },
          {
            "date": "2020-04-14",
            "product": "product1",
            "time": "24:00:00",
            "price": 9.0
          },
          {
            "date": "2020-04-14",
            "product": "product2",
            "time": "06:00:00",
            "price": 9.0
          },
          {
            "date": "2020-04-14",
            "product": "product2",
            "time": "12:00:00",
            "price": 16.0
          },
          {
            "date": "2020-04-14",
            "product": "product2",
            "time": "18:00:00",
            "price": 15.0
          },
          {
            "date": "2020-04-14",
            "product": "product2",
            "time": "24:00:00",
            "price": 11.0
          },
          {
            "date": "2020-04-15",
            "product": "product1",
            "time": "N/A",
            "price": -1
          },
          {
            "date": "2020-04-15",
            "product": "product2",
            "time": "N/A",
            "price": -1
          }
        ]
      }
    ],
    "identifier": 61211172
  },
  {
    "context": [
      "I am trying to process some string which has special characters in it like `abc123#45` or `ab$123` or `qwe&amp;123`.",
      "In json file : `foo=qwe$123`",
      "foo=`cat tmp_json | jq -r  &#39;.keys.foo&#39;`",
      "But it is coming like :\r\n\r\n    foo=qwe23",
      "JSON input\r\n\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;xyz&quot;,\r\n        &quot;version&quot;: 7,\r\n        &quot;lastUpdated&quot;: 1585551422521\r\n      },\r\n      &quot;keys&quot;: {\r\n        &quot;abc&quot;: &quot;qwe$123&quot;,\r\n        &quot;foo&quot;: &quot;qwe$123&quot;\r\n      }\r\n    }\r\n\r\n",
      "When shell strings contain special characters that you do not want to be interpreted specially by the shell, you have to quote them using single quotes, e.g. `foo=&#39;qwe$123&#39;`",
      "Using bash 4.x, the form \r\n\r\n    x=`...` \r\n\r\ndoes not present any problems with respect to characters such `$`, `#`, or `&amp;`, though it should be noted that the preferred form for such assignments is `x=$(...)`"
    ],
    "utterance": "Extract the value at .keys.foo that contains special characters such as $ and assign it to a shell variable without losing any characters.",
    "expressions": [
      ".keys.foo"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "name": "xyz",
            "version": 7,
            "lastUpdated": 1585551422521
          },
          "keys": {
            "abc": "qwe$123",
            "foo": "qwe$123"
          }
        },
        "output": "qwe$123"
      }
    ],
    "identifier": 60927841
  },
  {
    "context": [
      "The problem is, i dont understand how to get the entire JSON (it's huge) with my modified values.  Is this possible in jq?  I seem to only be able to get the parts that i modified.  I want the entire thing, with the parts that i modified in there.",
      "you are missing parentheses to turn the left-hand side of the assignment into a single path expression:",
      "(\n  .spec.install.spec.deployments[].spec.template.spec.containers[].env[]\n  | select(.name | contains(\"_IMAGE\"))\n  | .value\n) |= sub(\"registry.redhat.io\"; \"repo.home.nicknach.net:5000\"; \"g\")"
    ],
    "utterance": "Replace all occurrences of 'registry.redhat.io' with 'repo.home.nicknach.net:5000' in the value field for every env variable whose name contains '_IMAGE', and return the entire updated document with changes embedded.",
    "expressions": [
      "(\n  .spec.install.spec.deployments[].spec.template.spec.containers[].env[]\n  | select(.name | contains(\"_IMAGE\"))\n  | .value\n) |= sub(\"registry.redhat.io\"; \"repo.home.nicknach.net:5000\"; \"g\")"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "install": {
              "spec": {
                "deployments": [
                  {
                    "spec": {
                      "template": {
                        "spec": {
                          "containers": [
                            {
                              "env": [
                                {
                                  "name": "ES_IMAGE",
                                  "value": "registry.redhat.io/yada"
                                },
                                {
                                  "name": "KIBANA_IMAGE",
                                  "value": "registry.redhat.io/yada"
                                },
                                {
                                  "name": "other_var",
                                  "value": "not a registry.redhat.io"
                                }
                              ]
                            },
                            {
                              "env": [
                                {
                                  "name": "ES_IMAGE",
                                  "value": "registry.redhat.io/yada"
                                },
                                {
                                  "name": "KIBANA_IMAGE",
                                  "value": "registry.redhat.io/yada"
                                }
                              ]
                            }
                          ]
                        }
                      }
                    }
                  }
                ]
              }
            }
          }
        },
        "output": {
          "spec": {
            "install": {
              "spec": {
                "deployments": [
                  {
                    "spec": {
                      "template": {
                        "spec": {
                          "containers": [
                            {
                              "env": [
                                {
                                  "name": "ES_IMAGE",
                                  "value": "repo.home.nicknach.net:5000/yada"
                                },
                                {
                                  "name": "KIBANA_IMAGE",
                                  "value": "repo.home.nicknach.net:5000/yada"
                                },
                                {
                                  "name": "other_var",
                                  "value": "not a registry.redhat.io"
                                }
                              ]
                            },
                            {
                              "env": [
                                {
                                  "name": "ES_IMAGE",
                                  "value": "repo.home.nicknach.net:5000/yada"
                                },
                                {
                                  "name": "KIBANA_IMAGE",
                                  "value": "repo.home.nicknach.net:5000/yada"
                                }
                              ]
                            }
                          ]
                        }
                      }
                    }
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 60910745
  },
  {
    "context": [
      "Here\u2019s a solution to the structural problem with `jq`:\r\n\r\n    .spec |= ({selector: {matchLabels: {app: \"test-app\"}}} + .)\r\n",
      "$ yq --yaml-output '.spec |= ({selector: {matchLabels: {app: \"test-app\"}}} + .)' </tmp/your-yaml-file.yaml"
    ],
    "utterance": "Insert a field 'selector: {matchLabels: {app: \"test-app\"}}' at the beginning of the 'spec' object, before other fields, for the first occurrence of 'spec'.",
    "expressions": [
      ".spec |= ({selector: {matchLabels: {app: \"test-app\"}}} + .)"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "replicas": 1,
            "strategy": {
              "type": "Recreate"
            }
          }
        },
        "output": {
          "spec": {
            "selector": {
              "matchLabels": {
                "app": "test-app"
              }
            },
            "replicas": 1,
            "strategy": {
              "type": "Recreate"
            }
          }
        }
      }
    ],
    "identifier": 61109518
  },
  {
    "context": [
      "My question is how to join image_files and annotations with joint condition of",
      "- annotations.attributes.type == \"word\" AND",
      "- annotations.label' length == 4.",
      "The final result should be as follows:",
      "{\n  \"four_letter_word_image_files_with_label\": [\n    {\n      \"id\": \"img_0002\",\n      \"width\": 128,\n      \"heigt\": 32,\n      \"file_name\": \"img_0004.png\"\n      \"label\": \"Good\"\n    }\n  ]\n}",
      "def Hongsoog:\n  def makemap: reduce .annotations[] as $item ({}; .[$item.image_id]=$item) ;\n  def join:    makemap as $idx | [ .image_files[] | { i:., a: $idx[.id] } ] ;\n  def isword:  .a.attributes.type == \"word\" ;\n  def islen4:  .a.label | length == 4 ;\n  def format:  .i.label = .a.label | .i ; \n  def result:  [ join[] | select(isword and islen4) | format ];\n  {\n    \"four_letter_word_image_files_with_label\": result\n  };\n\nHongsoog"
    ],
    "utterance": "Join image_files and annotations such that attributes.type is \"word\" and label has length 4; output the corresponding image_files entries with label added under key four_letter_word_image_files_with_label.",
    "expressions": [
      "def makemap: reduce .annotations[] as $item ({}; .[$item.image_id] = $item);\ndef join: makemap as $idx | [ .image_files[] | { i: ., a: $idx[.id] } ];\ndef isword: .a.attributes.type == \"word\";\ndef islen4: .a.label | length == 4;\ndef format: .i.label = .a.label | .i;\ndef result: [ join[] | select(isword and islen4) | format ];\n{ \"four_letter_word_image_files_with_label\": result };"
    ],
    "data": [
      {
        "input": {
          "image_files": [
            {
              "id": "img_0001",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0001.png"
            },
            {
              "id": "img_0002",
              "width": 128,
              "heigt": 32,
              "file_name": "img_0002.png"
            },
            {
              "id": "img_0003",
              "width": 32,
              "heigt": 32,
              "file_name": "img_0003.png"
            },
            {
              "id": "img_0004",
              "width": 160,
              "heigt": 32,
              "file_name": "img_0004.png"
            }
          ],
          "annotations": [
            {
              "id": "ann_0001",
              "image_id": "img_0001",
              "label": "A",
              "attributes": {
                "type": "letter",
                "augmented": false
              }
            },
            {
              "id": "ann_0002",
              "image_id": "img_0002",
              "label": "Good",
              "attributes": {
                "type": "word",
                "augmented": false
              }
            },
            {
              "id": "ann_0003",
              "image_id": "img_0003",
              "label": "C",
              "attributes": {
                "type": "letter",
                "augmented": false
              }
            },
            {
              "id": "ann_0004",
              "image_id": "img_0004",
              "label": "Hello",
              "attributes": {
                "type": "word",
                "augmented": false
              }
            }
          ]
        },
        "output": {
          "four_letter_word_image_files_with_label": [
            {
              "id": "img_0002",
              "width": 128,
              "heigt": 32,
              "file_name": "img_0002.png",
              "label": "Good"
            }
          ]
        }
      }
    ],
    "identifier": 60971032
  },
  {
    "context": [
      "I tried to parse the project sonar database by using a jq if statement with test and regex, like this \r\n\r\n```\r\njq -r 'if (.name | test(\"\\\\.example\\\\.com$\") ) then . else empty end'\r\n```",
      "zcat sonar.json.gz | jq --arg a \"$b\" -r 'if (.name | test($a)) then . else empty end'",
      "If I set --arg a \"\\\\\\\\.example\\\\\\\\.com$\", it works.",
      "A='\\.example\\.com$'\r\necho A is $A\r\njq -M --arg a \"$A\" 'select(.value | test($a))'",
      "{ \"value\": \"foo\" }\r\n{ \"value\": \"foo.example.com\" }",
      "It produces\r\n\r\nA is \\.example\\.com$\r\n{\r\n  \"value\": \"foo.example.com\"\r\n}"
    ],
    "utterance": "Filter objects where the 'name' (or 'value') field matches the regular expression '\\.example\\.com$'.",
    "expressions": [
      "jq -r 'if (.name | test(\"\\\\.example\\\\.com$\") ) then . else empty end'",
      "jq --arg a \"$b\" -r 'if (.name | test($a)) then . else empty end'",
      "jq -M --arg a \"$A\" 'select(.value | test($a))'"
    ],
    "data": [
      {
        "input": {
          "value": "foo"
        },
        "output": null
      },
      {
        "input": {
          "value": "foo.example.com"
        },
        "output": {
          "value": "foo.example.com"
        }
      }
    ],
    "identifier": 61098501
  },
  {
    "context": [
      "I have this data in input:\r\n\r\n    {  \"connectionHistory\": [\r\n    {\r\n      \"endTime\": 1585571806,\r\n      \"bytesSent\": 31588,\r\n      \"startTime\": 1585571453,\r\n      \"duration\": 353,\r\n      \"bytesReceived\": 68711,\r\n      \"virtualIpAddress\": \"10.20.1.102\",\r\n      \"remoteIpAddress\": \"172.16.15.183\"\r\n    },\r\n    ... ]}",
      "And like to have in output something like:\r\n\r\n    Start               End                 Duration    IP client       IP remote      Received       Sent\r\n    01 Apr 2020, 16:13 \t01 Apr 2020, 16:15 \t02m 11s \t10.20.1.102 \t5.170.193.103 \t475.15 K \t2.01 M",
      "Now (before probably), I need to convert Unix Timestamp to DateTime.",
      "I suppose using todateiso8601 function, but can't insert it correctly."
    ],
    "utterance": "Convert all records' Unix timestamps to formatted date-time strings and output a table with columns for start and end timestamps (as formatted date-time), duration as minutes and seconds, client and remote IP, received and sent bytes with 'K' and 'M' suffixes, and rows sorted by descending end time.",
    "expressions": [
      ".connectionHistory | sort_by(-.endTime) | map({ Start: (.startTime | strflocaltime(\"%d %b %Y, %H:%M\")), End: (.endTime | strflocaltime(\"%d %b %Y, %H:%M\")), Duration: (.duration as $s | \"\u001b[1m\" + ((($s/60)|floor|tostring) + \"m \" + ($s%60|tostring) + \"s\")), \"IP client\": .virtualIpAddress, \"IP remote\": .remoteIpAddress, Received: (.bytesReceived as $b | if $b >= 1000000 then ((($b / 1000000)|floor) | tostring) + \".\" + ((($b % 1000000)/10000)|round|tostring) + \" M\" elif $b >= 1000 then ((($b / 1000)|floor) | tostring) + \".\" + ((($b % 1000)/10)|round|tostring) + \" K\" else ($b|tostring) end), Sent: (.bytesSent as $b | if $b >= 1000000 then ((($b / 1000000)|floor) | tostring) + \".\" + ((($b % 1000000)/10000)|round|tostring) + \" M\" elif $b >= 1000 then ((($b / 1000)|floor) | tostring) + \".\" + ((($b % 1000)/10)|round|tostring) + \" K\" else ($b|tostring) end) }) | (.[0] | keys_unsorted | @tsv), (.[] | [.[]] | @tsv)"
    ],
    "data": [
      {
        "input": {
          "connectionHistory": [
            {
              "endTime": 1585571806,
              "bytesSent": 31588,
              "startTime": 1585571453,
              "duration": 353,
              "bytesReceived": 68711,
              "virtualIpAddress": "10.20.1.102",
              "remoteIpAddress": "172.16.15.183"
            },
            {
              "endTime": 1585591333,
              "bytesSent": 21927,
              "startTime": 1585591095,
              "duration": 238,
              "bytesReceived": 51041,
              "virtualIpAddress": "10.20.1.102",
              "remoteIpAddress": "172.16.13.75"
            },
            {
              "endTime": 1585592547,
              "bytesSent": 4630423,
              "startTime": 1585591333,
              "duration": 1214,
              "bytesReceived": 678052,
              "virtualIpAddress": "10.20.1.102",
              "remoteIpAddress": "172.16.13.75"
            },
            {
              "endTime": 1585743727,
              "bytesSent": 2153310,
              "startTime": 1585743512,
              "duration": 215,
              "bytesReceived": 499382,
              "virtualIpAddress": "10.20.1.102",
              "remoteIpAddress": "172.16.12.209"
            }
          ]
        }
      }
    ],
    "identifier": 60974008
  },
  {
    "context": [
      "How can i get the output to just be a single boolean.",
      "I have tried using the 'any' function:",
      "jq -e '[.differences[].afterBlob.path | contains (\"sandbox_app\") or contains (\"sandbox_cicd\")] | any'",
      "jq -e '.differences | map(.afterBlob.path | contains (\"sandbox_app\") or contains (\"sandbox_cicd\")) | any'",
      "any(.differences[]; .afterBlob.path | contains (\"sandbox_app\") or contains (\"sandbox_cicd\") )"
    ],
    "utterance": "Return true if any element's afterBlob.path contains \"sandbox_app\" or \"sandbox_cicd\", otherwise false.",
    "expressions": [
      "[.differences[].afterBlob.path | contains(\"sandbox_app\") or contains(\"sandbox_cicd\")] | any",
      ".differences | map(.afterBlob.path | contains(\"sandbox_app\") or contains(\"sandbox_cicd\")) | any",
      "any(.differences[]; .afterBlob.path | contains(\"sandbox_app\") or contains(\"sandbox_cicd\"))"
    ],
    "data": [
      {
        "input": {
          "differences": [
            {
              "beforeBlob": {
                "blobId": "a9033f024bf",
                "path": "test1",
                "mode": "100644"
              },
              "afterBlob": {
                "blobId": "e27f2609943e",
                "path": "test1",
                "mode": "100644"
              },
              "changeType": "M"
            },
            {
              "beforeBlob": {
                "blobId": "ec669676314",
                "path": "test2",
                "mode": "100644"
              },
              "afterBlob": {
                "blobId": "38867b90873",
                "path": "test2",
                "mode": "100644"
              },
              "changeType": "M"
            },
            {
              "afterBlob": {
                "blobId": "ae8c5bdb690",
                "path": "sandbox_app/test3",
                "mode": "100644"
              },
              "changeType": "A"
            },
            {
              "afterBlob": {
                "blobId": "97819f382ad9",
                "path": "sandbox_cicd/test3",
                "mode": "100644"
              },
              "changeType": "A"
            }
          ]
        },
        "output": true
      }
    ],
    "identifier": 61369968
  },
  {
    "context": [
      "I'd like to use JQ to merge the two files to look like the following:",
      "[\n  {\n    \"name\": \"Project1\",\n    \"owner\": \"owner1\",\n    \"base\": \"A\"\n  },\n  {\n    \"name\": \"Project2\",\n    \"owner\": \"owner2\",\n    \"base\": \"B\"\n  }\n]",
      "$ jq 'input as $owners | map(.owner = $owners[.name])' projects.json owners.json"
    ],
    "utterance": "Merge records, adding an owner field to each project, where the owner value is looked up by project name.",
    "expressions": [
      "input as $owners | map(.owner = $owners[.name])"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "Project1",
              "base": "A"
            },
            {
              "name": "Project2",
              "base": "B"
            }
          ],
          {
            "Project1": "owner1",
            "Project2": "owner2"
          }
        ],
        "output": [
          {
            "name": "Project1",
            "base": "A",
            "owner": "owner1"
          },
          {
            "name": "Project2",
            "base": "B",
            "owner": "owner2"
          }
        ]
      }
    ],
    "identifier": 61092531
  },
  {
    "context": [
      "For each `book`, `movie` and `dvd` a client has I need to reference the client id and name.",
      "Below is a representation of the output I would like to achieve:",
      "c_id      | c_name   | type   | sku | description            |",
      "jq --compact-output '.report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description]))'",
      "If you want true CSV you can add `| @csv` on the end",
      "jq --compact-output '.report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description])) | @csv'",
      "jq --compact-output --raw-output '.report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description])) | join(\"|\")'"
    ],
    "utterance": "Flatten the nested client items so each book, movie, and dvd record appears as a row with the client's id, name, the type, sku, and description, in a tabular or CSV format.",
    "expressions": [
      ".report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description]))",
      ".report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description])) | @csv",
      ".report.clients[] | [.id, .name] + ((.books[] | [\"books\", .sku, .description]), (.movies[] | [\"movie\", .sku, .description]), (.dvds[] | [\"dvds\", .sku, .description])) | join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "report": {
            "clients": [
              {
                "id": "001",
                "name": "client_1",
                "books": [
                  {
                    "sku": "100",
                    "description": "book title: book-A"
                  },
                  {
                    "sku": "101",
                    "description": "book title: book-B"
                  },
                  {
                    "sku": "102",
                    "description": "book title: book-C"
                  }
                ],
                "movies": [
                  {
                    "sku": "200",
                    "description": "movie title: movie-A"
                  },
                  {
                    "sku": "201",
                    "description": "movie title: movie-B"
                  }
                ],
                "dvds": [
                  {
                    "sku": "300",
                    "description": "dvd title: dvd-A"
                  }
                ]
              },
              {
                "id": "002",
                "name": "client_2",
                "books": [
                  {
                    "sku": "100",
                    "description": "book title: book-A"
                  },
                  {
                    "sku": "101",
                    "description": "book title: book-B"
                  },
                  {
                    "sku": "102",
                    "description": "book title: book-C"
                  },
                  {
                    "sku": "103",
                    "description": "book title: book-D"
                  },
                  {
                    "sku": "104",
                    "description": "book title: book-E"
                  }
                ],
                "movies": [
                  {
                    "sku": "200",
                    "description": "movie title: movie-A"
                  }
                ],
                "dvds": [
                  {
                    "sku": "300",
                    "description": "dvd title: dvd-A"
                  },
                  {
                    "sku": "301",
                    "description": "dvd title: dvd-B"
                  },
                  {
                    "sku": "302",
                    "description": "dvd title: dvd-C"
                  },
                  {
                    "sku": "303",
                    "description": "dvd title: dvd-D"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          [
            "001",
            "client_1",
            "books",
            "100",
            "book title: book-A"
          ],
          [
            "001",
            "client_1",
            "books",
            "101",
            "book title: book-B"
          ],
          [
            "001",
            "client_1",
            "books",
            "102",
            "book title: book-C"
          ],
          [
            "001",
            "client_1",
            "movie",
            "200",
            "movie title: movie-A"
          ],
          [
            "001",
            "client_1",
            "movie",
            "201",
            "movie title: movie-B"
          ],
          [
            "001",
            "client_1",
            "dvds",
            "300",
            "dvd title: dvd-A"
          ],
          [
            "002",
            "client_2",
            "books",
            "100",
            "book title: book-A"
          ],
          [
            "002",
            "client_2",
            "books",
            "101",
            "book title: book-B"
          ],
          [
            "002",
            "client_2",
            "books",
            "102",
            "book title: book-C"
          ],
          [
            "002",
            "client_2",
            "books",
            "103",
            "book title: book-D"
          ],
          [
            "002",
            "client_2",
            "books",
            "104",
            "book title: book-E"
          ],
          [
            "002",
            "client_2",
            "movie",
            "200",
            "movie title: movie-A"
          ],
          [
            "002",
            "client_2",
            "dvds",
            "300",
            "dvd title: dvd-A"
          ],
          [
            "002",
            "client_2",
            "dvds",
            "301",
            "dvd title: dvd-B"
          ],
          [
            "002",
            "client_2",
            "dvds",
            "302",
            "dvd title: dvd-C"
          ],
          [
            "002",
            "client_2",
            "dvds",
            "303",
            "dvd title: dvd-D"
          ]
        ]
      }
    ],
    "identifier": 61367733
  },
  {
    "context": [
      "I used: jq -r '.[] | .file_id, .cases[].project.project_id' my_file.json > test6.tx",
      "and got a file that looks like this: d47c1aaa\nSKCM\n5b8564e3\nCESC\n9b0b7bb0\nGBM\nHowever, I want it to look like this d47c1aaa  SKCM\n5b8564e3  CESC\n9b0b7bb0  GBM",
      "jq -r '.[] | \"\\(.file_id) \\(.cases[].project.project_id)\"' all_somatic_annotated_TCGA.json > test.txt"
    ],
    "utterance": "For each item, output file_id and the related project_id from cases[].project.project_id on the same line, separated by a space.",
    "expressions": [
      ".[] | \"\b(.file_id) \\(.cases[].project.project_id)\""
    ],
    "data": [
      {
        "input": [
          {
            "file_id": "d47c1aaa",
            "cases": [
              {
                "project": {
                  "project_id": "SKCM"
                }
              }
            ]
          },
          {
            "file_id": "5b8564e3",
            "cases": [
              {
                "project": {
                  "project_id": "CESC"
                }
              }
            ]
          },
          {
            "file_id": "9b0b7bb0",
            "cases": [
              {
                "project": {
                  "project_id": "GBM"
                }
              }
            ]
          }
        ],
        "output": [
          "d47c1aaa SKCM",
          "5b8564e3 CESC",
          "9b0b7bb0 GBM"
        ]
      }
    ],
    "identifier": 61089016
  },
  {
    "context": [
      "I'm working with jq 1.6 to get the last entry in an object. It *should* work like this:",
      "{ \"1\": { \"a\": \"1\" }, \"2\": { \"a\": \"2\" }, \"3\": { \"a\": \"3\" } }",
      "echo $result\n{ \"3\": { \"a\": \"3\" } }",
      "You can use the following :",
      "jq 'to_entries | [last] | from_entries'"
    ],
    "utterance": "Return the last key-value pair in an object as a single-entry object.",
    "expressions": [
      "to_entries | [last] | from_entries"
    ],
    "data": [
      {
        "input": {
          "1": {
            "a": "1"
          },
          "2": {
            "a": "2"
          },
          "3": {
            "a": "3"
          }
        },
        "output": {
          "3": {
            "a": "3"
          }
        }
      }
    ],
    "identifier": 61101083
  },
  {
    "context": [
      "Now I need to come up with some script from where I can remove json object `\"1234\"` completely.",
      "If the `property` value is `Hat` then only I want to remove the key present but if property value is something else then I don't want to remove that key.",
      "jq '{props: [.props[] | if .property == \"Hat\" then del(.data.\"1234\") else . end]}'",
      "jq '{props: [.props[] | (select(.property == \"Hat\") | del(.data[\"1234\"])), select(.property != \"Hat\")]}'"
    ],
    "utterance": "Remove the key '1234' from the 'data' object within elements of the 'props' array that have 'property' equal to 'Hat', leaving other objects unchanged.",
    "expressions": [
      "{props: [.props[] | if .property == \"Hat\" then del(.data.\"1234\") else . end]}",
      "{props: [.props[] | (select(.property == \"Hat\") | del(.data[\"1234\"])), select(.property != \"Hat\")]}"
    ],
    "data": [
      {
        "input": {
          "props": [
            {
              "property": "Hat",
              "data": {
                "1234": {
                  "tt": true
                },
                "7890": {
                  "tt": true
                }
              }
            },
            {
              "property": "Shirt",
              "data": {
                "1234": {
                  "tt": true
                },
                "2222": {
                  "tt": false
                }
              }
            }
          ]
        },
        "output": {
          "props": [
            {
              "property": "Hat",
              "data": {
                "7890": {
                  "tt": true
                }
              }
            },
            {
              "property": "Shirt",
              "data": {
                "1234": {
                  "tt": true
                },
                "2222": {
                  "tt": false
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 61371086
  },
  {
    "context": [
      "to summarise, for the above json, I need a `magic_expression`\n\n$ jq 'magic_expression' log.json\n\nthat will return\n\n\"random_param_name_1\":\"random_value_1\",\"random_param_name_2\":\"random_value_2\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\"\n\"random_param_name_1\":\"random_value_1\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\",\"random_param_name_5\":\"random_value_5\"",
      "def format: \"\\\"\\(.key)\\\":\\\"\\(.value)\\\"\" ;\nmap(.input | to_entries | map(format) | sort ) | unique[] | join(\",\")",
      "which produces \n\n\"random_param_name_1\":\"random_value_1\",\"random_param_name_2\":\"random_value_2\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\"\n\"random_param_name_1\":\"random_value_1\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\",\"random_param_name_5\":\"random_value_5\"\nwhen run with `-r` / `--raw-output`"
    ],
    "utterance": "Print, in a single line for each entry, all key-value pairs from input objects with keys sorted and formatted as \"key\":\"value\", showing only unique combinations.",
    "expressions": [
      "def format: \"\\\"\\(.key)\\\":\\\"\\(.value)\\\"\" ; map(.input | to_entries | map(format) | sort ) | unique[] | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "input": {
              "random_param_name_1": "random_value_1",
              "random_param_name_2": "random_value_2",
              "random_param_name_3": "random_value_3",
              "random_param_name_4": "random_value_4"
            },
            "output": {
              "some_key_we_dont_care_about": "some_value_we_dont_care_about"
            },
            "status_code": 200
          },
          {
            "input": {
              "random_param_name_1": "random_value_1",
              "random_param_name_4": "random_value_4",
              "random_param_name_3": "random_value_3",
              "random_param_name_5": "random_value_5"
            },
            "output": {
              "some_key_we_dont_care_about": "some_value_we_dont_care_about"
            },
            "status_code": 200
          }
        ],
        "output": [
          "\"random_param_name_1\":\"random_value_1\",\"random_param_name_2\":\"random_value_2\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\"",
          "\"random_param_name_1\":\"random_value_1\",\"random_param_name_3\":\"random_value_3\",\"random_param_name_4\":\"random_value_4\",\"random_param_name_5\":\"random_value_5\""
        ]
      }
    ],
    "identifier": 61084546
  },
  {
    "context": [
      "Populate `args.json` with `code` values to be selected, it'll look like this:\n```\n\"123\"\n\"234\"\n```",
      "Then convert `arrlstProperty` into an object by keying each element with its `code` value, then index resulting object with keys stored in `args.json`. E.g:\n```\njq '.arrlstProperty | INDEX(.code)[inputs]' input_file.json args.json\n```",
      "Here is a script for version < 1.6\n\n```\njq '.arrlstProperty | map(.code as $x | select( any($codes[]; . == $x )))' --slurpfile codes args.json input_file.json\n```"
    ],
    "utterance": "Select all objects from arrlstProperty whose code is included in a list of codes provided in a separate file.",
    "expressions": [
      ".arrlstProperty | INDEX(.code)[inputs]",
      ".arrlstProperty | map(.code as $x | select( any($codes[]; . == $x )))"
    ],
    "data": [
      {
        "input": {
          "user": {
            "id": 100,
            "action": "UPDATE",
            "years_experience": 0
          },
          "arrlstProperty": [
            {
              "id": 12345,
              "code": "EB-123",
              "galleries": [
                {
                  "action": "UPDATE",
                  "id": 90,
                  "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 01"
                },
                {
                  "action": "UPDATE",
                  "id": 91,
                  "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 02"
                }
              ]
            },
            {
              "id": 12346,
              "code": "EB-234",
              "galleries": [
                {
                  "action": "UPDATE",
                  "id": 92,
                  "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 01"
                },
                {
                  "action": "UPDATE",
                  "id": 93,
                  "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 02"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": 12345,
            "code": "EB-123",
            "galleries": [
              {
                "action": "UPDATE",
                "id": 90,
                "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 01"
              },
              {
                "action": "UPDATE",
                "id": 91,
                "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 02"
              }
            ]
          },
          {
            "id": 12346,
            "code": "EB-234",
            "galleries": [
              {
                "action": "UPDATE",
                "id": 92,
                "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 01"
              },
              {
                "action": "UPDATE",
                "id": 93,
                "alt": "Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le\u00f3n, 11448639 No. 02"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 61154881
  },
  {
    "context": [
      "I want to output every record in one single line like this (because AWS Athena requires this format):",
      "{ \"__metadata\": {\"id\": \"12\", \"uri\": \"xyz\", \"type\": \"Result\"}, \"YEAR\": \"2018\", \"MOW\": \"0102\",  \"UNIT\": \"1.2761625\", \"VALUE1\": \"0\", \"VALUE2\": \"0\", \"SIGNAL\": \"0\"}",
      "{ \"__metadata\": {\"id\": \"13\", \"uri\": \"xyz\", \"type\": \"Result\"}, \"YEAR\": \"2018\", \"MOW\": \"0102\",  \"UNIT\": \"1.2761625\", \"VALUE1\": \"0\", \"VALUE2\": \"0\", \"SIGNAL\": \"0\"}",
      "I used \" jq -c . myjson.json\" for formatting. I expected it to put each record in one single line, but instead it put every record next to each other so my json holds one very long single line."
    ],
    "utterance": "Produce each object inside .d.results as its own compact, single-line output entry.",
    "expressions": [
      ".d.results[] | @json"
    ],
    "data": [
      {
        "input": {
          "d": {
            "results": [
              {
                "__metadata": {
                  "id": "12",
                  "uri": "xyz",
                  "type": "Result"
                },
                "YEAR": "2018",
                "MOW": "0102",
                "UNIT": "1.2761625",
                "VALUE1": "0",
                "VALUE2": "0",
                "SIGNAL": "0"
              },
              {
                "__metadata": {
                  "id": "13",
                  "uri": "xyz",
                  "type": "Result"
                },
                "YEAR": "2018",
                "MOW": "0102",
                "UNIT": "1.2761625",
                "VALUE1": "0",
                "VALUE2": "0",
                "SIGNAL": "0"
              }
            ]
          }
        },
        "output": [
          "{\"__metadata\":{\"id\":\"12\",\"uri\":\"xyz\",\"type\":\"Result\"},\"YEAR\":\"2018\",\"MOW\":\"0102\",\"UNIT\":\"1.2761625\",\"VALUE1\":\"0\",\"VALUE2\":\"0\",\"SIGNAL\":\"0\"}",
          "{\"__metadata\":{\"id\":\"13\",\"uri\":\"xyz\",\"type\":\"Result\"},\"YEAR\":\"2018\",\"MOW\":\"0102\",\"UNIT\":\"1.2761625\",\"VALUE1\":\"0\",\"VALUE2\":\"0\",\"SIGNAL\":\"0\"}"
        ]
      }
    ],
    "identifier": 61438493
  },
  {
    "context": [
      "I want to replace all keys containing \"dots\" by \"dashes\"",
      ".activies |= walk(\n  if type == \"object\" then\n    with_entries(\n      .key |= gsub(\"\\\\.\";\"-\")\n    )\n  else . end\n)\n"
    ],
    "utterance": "Replace every key containing a dot with the same key where dots are replaced by dashes, under the 'activies' field.",
    "expressions": [
      ".activies |= walk(\n  if type == \"object\" then\n    with_entries(\n      .key |= gsub(\"\\\\.\";\"-\")\n    )\n  else . end\n)"
    ],
    "data": [
      {
        "input": {
          "user": {
            "advertisingID": "617a68"
          },
          "deviceTs": 1575387020137,
          "activies": [
            {
              "ts": 1575617868326,
              "appsUsage": {
                "isFull": true,
                "data": [
                  {
                    "com.orange.phone": 44009
                  }
                ],
                "startTs": 1575617281541
              }
            },
            {
              "ts": 1575618968326,
              "appsUsage": {
                "isFull": true,
                "data": [
                  {
                    "uk.green.launcher2": 4354
                  },
                  {
                    "com.black.phone": 1232
                  }
                ],
                "startTs": 1575617281541
              }
            }
          ]
        },
        "output": {
          "user": {
            "advertisingID": "617a68"
          },
          "deviceTs": 1575387020137,
          "activies": [
            {
              "ts": 1575617868326,
              "appsUsage": {
                "isFull": true,
                "data": [
                  {
                    "com-orange-phone": 44009
                  }
                ],
                "startTs": 1575617281541
              }
            },
            {
              "ts": 1575618968326,
              "appsUsage": {
                "isFull": true,
                "data": [
                  {
                    "uk-green-launcher2": 4354
                  },
                  {
                    "com-black-phone": 1232
                  }
                ],
                "startTs": 1575617281541
              }
            }
          ]
        }
      }
    ],
    "identifier": 61423991
  },
  {
    "context": [
      "I have a string which is formated as a long string (no newlines) like so:",
      "<NAME1>ID1>CODE1a>CODE1b>><NAME2>ID2>CODE2a>CODE2b>><NAME3>ID3>CODE3a>CODE3b>>",
      "The idea is convert this string to JSON:",
      "{\n  \"ID1\": [\n    \"NAME1\",\n    \"CODE1a\",\n    \"CODE1b\"\n  ],\n  \"ID2\": [\n    \"NAME2\",\n    \"CODE2a\",\n    \"CODE2b\"\n  ],\n  \"ID3\": [\n    \"NAME3\",\n    \"CODE3a\",\n    \"CODE3b\"\n  ]\n}",
      "The whole thing can be done using just jq, e.g.:",
      "jq -R '\n  sub(\"^<\";\"\")\n  | split(\">><\")\n  | map(split(\">\"))\n  | map( { (.[1]) : (.[0:1] + (.[2:] | map(select(.!=\"\")))) } )\n  | add\n'"
    ],
    "utterance": "Transform a single-line string formatted as <NAME>ID>CODEa>CODEb>><...> into an object mapping each ID to an array of name and codes.",
    "expressions": [
      "jq -R '\n  sub(\"^<\";\"\")\n  | split(\">><\")\n  | map(split(\">\"))\n  | map( { (.[1]) : (.[0:1] + (.[2:] | map(select(.!=\"\")))) } )\n  | add\n'"
    ],
    "data": [
      {
        "input": "<NAME1>ID1>CODE1a>CODE1b>><NAME2>ID2>CODE2a>CODE2b>><NAME3>ID3>CODE3a>CODE3b>>",
        "output": {
          "ID1": [
            "NAME1",
            "CODE1a",
            "CODE1b"
          ],
          "ID2": [
            "NAME2",
            "CODE2a",
            "CODE2b"
          ],
          "ID3": [
            "NAME3",
            "CODE3a",
            "CODE3b"
          ]
        }
      }
    ],
    "identifier": 61132661
  },
  {
    "context": [
      "Here I want to write function which will get file name as input parameter and now inside function I want to read last Object array and two fields from which  **build** and **win** ans stor there values is variable ex **total**  which will contain addition of **build** and **win**  and insert this value again inside JSON .",
      "so that final JSON will look like \n...{\n  \"Data\": {\n    \"Info\": [\n      {\n        \"tranID\": \"1\",\n        \"architecture\": \"thread_1\",\n        \"build\": \"110\",\n        \"win\": \"450\"\n      },\n      {\n        \"tranID\": \"2\",\n        \"architecture\": \"thread_2\",\n        \"build\": \"120\",\n        \"win\": \"455\",\n       \"total\": \"575\"\n      }\n    ]\n  }\n}",
      "now inside function I want to read last Object array and two fields from which  **build** and **win** ans stor there values is variable ex **total**  which will contain addition of **build** and **win**  and insert this value again inside JSON"
    ],
    "utterance": "Compute the sum of the build and win fields in the last object of the array at Data.Info, add this sum as a new total field to that object, and update the data structure.",
    "expressions": [
      ".Data.Info |= (.[-1] |= (. + {\"total\": ((.build|tonumber) + (.win|tonumber) | tostring)}))"
    ],
    "data": [
      {
        "input": {
          "Data": {
            "Info": [
              {
                "tranID": "1",
                "architecture": "thread_1",
                "build": "110",
                "win": "450"
              },
              {
                "tranID": "2",
                "architecture": "thread_2",
                "build": "120",
                "win": "455"
              }
            ]
          }
        },
        "output": {
          "Data": {
            "Info": [
              {
                "tranID": "1",
                "architecture": "thread_1",
                "build": "110",
                "win": "450"
              },
              {
                "tranID": "2",
                "architecture": "thread_2",
                "build": "120",
                "win": "455",
                "total": "575"
              }
            ]
          }
        }
      }
    ],
    "identifier": 61294311
  },
  {
    "context": [
      "I want to extract out of that the 1st occurrence of `format_id`.",
      "If your jq has `inputs` then it would be best to use it in conjunction with the -n command-line option and the following jq filter:",
      "first(inputs | select(.format_id ==\"18\"))",
      "If your jq does not have `inputs` ... then you'd have to use the -s command-line option, e.g. with the following filter:",
      "first(.[] | select(.format_id ==\"18\"))"
    ],
    "utterance": "Extract the first object with format_id equal to \"18\" from a stream of objects.",
    "expressions": [
      "first(inputs | select(.format_id == \"18\"))",
      "first(.[] | select(.format_id == \"18\"))"
    ],
    "data": [
      {
        "input": [
          {
            "format_id": "250"
          },
          {
            "format_id": "18"
          },
          {
            "format_id": "140"
          },
          {
            "format_id": "18"
          },
          {
            "format_id": "244"
          }
        ],
        "output": {
          "format_id": "18"
        }
      }
    ],
    "identifier": 61415700
  },
  {
    "context": [
      "I would like to fill a JSON file, that is still empty with the below values using JQ.",
      "[ // Data should goes here ]",
      "Expecting result:",
      "[\n     {\n      \"Name\": \"FileName\",\n      \"Size\": \"FileSize\",\n      \"Action\": \"Action taken\",\n     },\n \n     // and so on\n]",
      "And you want to append the JSON object to the existing array, or if the file is empty, create a new array with the object as its own element.",
      "jq --argjson x \"$object\" '. += [$x]' < \"$file\" > tmp.json"
    ],
    "utterance": "Append an object with Name \"FileName\", Size \"FileSize\", and Action \"Action taken\" to an array in a file, or create a new array containing this object if the file is empty.",
    "expressions": [
      ". += [{\"Name\": \"FileName\", \"Size\": \"FileSize\", \"Action\": \"Action taken\"}]",
      "jq --argjson x \"$object\" '. += [$x]' < \"$file\" > tmp.json"
    ],
    "data": [
      {
        "input": [],
        "output": [
          {
            "Name": "FileName",
            "Size": "FileSize",
            "Action": "Action taken"
          }
        ]
      },
      {
        "input": [
          {
            "previous": "value"
          }
        ],
        "output": [
          {
            "previous": "value"
          },
          {
            "Name": "FileName",
            "Size": "FileSize",
            "Action": "Action taken"
          }
        ]
      }
    ],
    "identifier": 61131327
  },
  {
    "context": [
      "The element I wish to match and remove is an object in the .chapter array - .tags.title that contains the text #MKR#",
      "Example Output JSON I want to achieve:",
      "You can filter out your chapters with something like this:",
      "jq '.chapters |= map(select(.tags.title | contains(\"#MKR#\") | not))' metadata.json"
    ],
    "utterance": "Remove all elements from chapters whose tags.title contains the text #MKR#, preserving the rest of the structure.",
    "expressions": [
      ".chapters |= map(select(.tags.title | contains(\"#MKR#\") | not))"
    ],
    "data": [
      {
        "input": {
          "chapters": [
            {
              "id": 0,
              "time_base": "1/3000",
              "start": 0,
              "start_time": "0.000000",
              "end": 9200,
              "end_time": "3.066667",
              "tags": {
                "title": "Start"
              }
            },
            {
              "id": 1,
              "time_base": "1/3000",
              "start": 9200,
              "start_time": "3.066667",
              "end": 15000,
              "end_time": "5.000000",
              "tags": {
                "title": "Example(1) #MKR#"
              }
            },
            {
              "id": 2,
              "time_base": "1/3000",
              "start": 15000,
              "start_time": "5.000000",
              "end": 18900,
              "end_time": "6.300000",
              "tags": {
                "title": "Example(2)"
              }
            },
            {
              "id": 3,
              "time_base": "1/3000",
              "start": 18900,
              "start_time": "6.300000",
              "end": 124299,
              "end_time": "41.433000",
              "tags": {
                "title": "Example(3) #MKR#"
              }
            },
            {
              "id": 4,
              "time_base": "1/3000",
              "start": 124299,
              "start_time": "41.433000",
              "end": 225700,
              "end_time": "75.233333",
              "tags": {
                "title": "Example(4) #MKR#"
              }
            },
            {
              "id": 5,
              "time_base": "1/3000",
              "start": 225700,
              "start_time": "75.233333",
              "end": 231900,
              "end_time": "77.300000",
              "tags": {
                "title": "Example(5) #MKR#"
              }
            }
          ],
          "format": {
            "filename": "video_mkr_temp.mp4",
            "nb_streams": 3,
            "nb_programs": 0,
            "format_name": "mov,mp4,m4a,3gp,3g2,mj2",
            "format_long_name": "QuickTime / MOV",
            "start_time": "0.000000",
            "duration": "968.300000",
            "size": "399977859",
            "bit_rate": "3304577",
            "probe_score": 100,
            "tags": {
              "major_brand": "mp42",
              "minor_version": "512",
              "compatible_brands": "isomiso2avc1mp41",
              "creation_time": "2020-04-12T00:46:21.000000Z"
            }
          }
        },
        "output": {
          "chapters": [
            {
              "id": 0,
              "time_base": "1/3000",
              "start": 0,
              "start_time": "0.000000",
              "end": 9200,
              "end_time": "3.066667",
              "tags": {
                "title": "Start"
              }
            },
            {
              "id": 2,
              "time_base": "1/3000",
              "start": 15000,
              "start_time": "5.000000",
              "end": 18900,
              "end_time": "6.300000",
              "tags": {
                "title": "Example(2)"
              }
            }
          ],
          "format": {
            "filename": "video_mkr_temp.mp4",
            "nb_streams": 3,
            "nb_programs": 0,
            "format_name": "mov,mp4,m4a,3gp,3g2,mj2",
            "format_long_name": "QuickTime / MOV",
            "start_time": "0.000000",
            "duration": "968.300000",
            "size": "399977859",
            "bit_rate": "3304577",
            "probe_score": 100,
            "tags": {
              "major_brand": "mp42",
              "minor_version": "512",
              "compatible_brands": "isomiso2avc1mp41",
              "creation_time": "2020-04-12T00:46:21.000000Z"
            }
          }
        }
      }
    ],
    "identifier": 61291303
  },
  {
    "context": [
      "What I would like, is to show only the records with detected == true and format them in a way that all the relevant info is visible in one single overview, without needing to scroll back.",
      "Ideally it would look like this:\nMicroWorld-eScan        14.0.409.0      20200418        Trojan.GenericKD.42992262\nMcAfee                  6.0.6.653       20200417        Artemis!A860FF8B038D\n...",
      "You could get an output close to what you showed but in valid json with this.",
      "jq '\n    .scans |= with_entries(\n        select(.value.detected)\n        | .value |= .version + \" / \" + .update + \" / \" + .result\n    )\n' vt-json.txt",
      "The filter select(.value.detected) removes tools which have not detected anything, while the filter .version + \" / \" + .update + \" / \" + .result formats the output in case of positive detection."
    ],
    "utterance": "Show only antivirus engine results where detected is true, displaying each engine's version, update, and result fields in a single, formatted line for all engines that detected a threat.",
    "expressions": [
      ".scans |= with_entries(select(.value.detected) | .value |= .version + \" / \" + .update + \" / \" + .result)"
    ],
    "data": [
      {
        "input": {
          "scans": {
            "Bkav": {
              "detected": false,
              "version": "1.3.0.9899",
              "result": null,
              "update": "20200418"
            },
            "MicroWorld-eScan": {
              "detected": true,
              "version": "14.0.409.0",
              "result": "Trojan.GenericKD.42992262",
              "update": "20200418"
            },
            "McAfee": {
              "detected": true,
              "version": "6.0.6.653",
              "result": "Artemis!A860FF8B038D",
              "update": "20200417"
            }
          }
        },
        "output": {
          "scans": {
            "MicroWorld-eScan": "14.0.409.0 / 20200418 / Trojan.GenericKD.42992262",
            "McAfee": "6.0.6.653 / 20200417 / Artemis!A860FF8B038D"
          }
        }
      }
    ],
    "identifier": 61290597
  },
  {
    "context": [
      "EDIT: What I want to print out at the end is basically the top-level `.name` value and each `.data` value where the `type == \"A\"`.",
      "Stay in the top-level then.",
      ".[]\n| select(.class == \"IN\" and .status == \"NOERROR\")\n| .name + \": \" + (.data.answers[] | select(.type == \"A\") .data)?"
    ],
    "utterance": "For each list entry with class equal to IN and status equal to NOERROR, output the name and each data value where the answer type is A.",
    "expressions": [
      ".[] | select(.class == \"IN\" and .status == \"NOERROR\") | .name + \": \" + (.data.answers[] | select(.type == \"A\") .data)?"
    ],
    "data": [
      {
        "input": [
          {
            "name": "aaaaa",
            "type": "A",
            "class": "IN",
            "status": "NOERROR",
            "data": {
              "answers": [
                {
                  "ttl": 30,
                  "type": "CNAME",
                  "class": "IN",
                  "name": "aaaaa",
                  "data": "bbbbb"
                },
                {
                  "ttl": 1800,
                  "type": "CNAME",
                  "class": "IN",
                  "name": "bbbbb",
                  "data": "ccccc"
                },
                {
                  "ttl": 60,
                  "type": "A",
                  "class": "IN",
                  "name": "ccccc",
                  "data": "1.2.3.4"
                }
              ]
            }
          }
        ],
        "output": [
          "aaaaa: 1.2.3.4"
        ]
      }
    ],
    "identifier": 61128129
  },
  {
    "context": [
      "input:\n\n>     {   \"asgs\": [\n>     {\n>       \"name\": \"test1\",\n>       \"instances\": [\n>         {\"id\": \"i-9fb75dc\", \"az\": \"us-east-1a\", \"state\": \"InService\"},\n>         {\"id\": \"i-95393ba\", \"az\": \"us-east-1a\", \"state\": \"Terminating:Wait\"},\n>         {\"id\": \"i-241fd0b\", \"az\": \"us-east-1b\", \"state\": \"InService\"}\n>       ]\n>     },\n>     {\n>       \"name\": \"test2\",\n>       \"instances\": [\n>         {\"id\": \"i-4bbab16\", \"az\": \"us-east-1a\", \"state\": \"InService\"},\n>         {\"id\": \"i-417c312\", \"az\": \"us-east-1b\", \"state\": \"InService\"}\n>       ]\n>     }   ] }",
      "output: \n\ntest1   i-9fb75dc       us-east-1a      InService\ntest1   i-95393ba       us-east-1a      Terminating:Wait\ntest1   i-241fd0b       us-east-1b      InService\ntest2   i-4bbab16       us-east-1a      InService\ntest2   i-417c312       us-east-1b      InService",
      "You may use this jq:\n\n    jq -r '.asgs[] | .name + \"\\t\" + (.instances[] | .id + \"\\t\" + .az + \"\\t\" + .state)' file.json",
      "A slight shorter (though marginally more complex) version of @anubhava's answer:\n\n    jq -r '.asgs[] | .name as $n | (.instances[] | [$n, .id, .az, .state] | @tsv)' file.json",
      "This \"remembers\" each name before producing a tab-separated line for each instance, inserting the correct name in each row."
    ],
    "utterance": "Produce a tab-separated table with each row containing the group name, instance id, availability zone, and state for every instance in every group.",
    "expressions": [
      ".asgs[] | .name + \"\\t\" + (.instances[] | .id + \"\\t\" + .az + \"\\t\" + .state)",
      ".asgs[] | .name as $n | (.instances[] | [$n, .id, .az, .state] | @tsv)"
    ],
    "data": [
      {
        "input": {
          "asgs": [
            {
              "name": "test1",
              "instances": [
                {
                  "id": "i-9fb75dc",
                  "az": "us-east-1a",
                  "state": "InService"
                },
                {
                  "id": "i-95393ba",
                  "az": "us-east-1a",
                  "state": "Terminating:Wait"
                },
                {
                  "id": "i-241fd0b",
                  "az": "us-east-1b",
                  "state": "InService"
                }
              ]
            },
            {
              "name": "test2",
              "instances": [
                {
                  "id": "i-4bbab16",
                  "az": "us-east-1a",
                  "state": "InService"
                },
                {
                  "id": "i-417c312",
                  "az": "us-east-1b",
                  "state": "InService"
                }
              ]
            }
          ]
        },
        "output": "test1\ti-9fb75dc\tus-east-1a\tInService\ntest1\ti-95393ba\tus-east-1a\tTerminating:Wait\ntest1\ti-241fd0b\tus-east-1b\tInService\ntest2\ti-4bbab16\tus-east-1a\tInService\ntest2\ti-417c312\tus-east-1b\tInService"
      }
    ],
    "identifier": 61139142
  },
  {
    "context": [
      "I want to produce the same json, but with all the property values in the \"data\" object are base64-decoded.",
      "$ jq '.data[] |= @base64d' example.json",
      "For example\n\n`jq '.data|map_values(@base64d)' example.json`"
    ],
    "utterance": "Produce the same structure, but with all values in the data object base64-decoded.",
    "expressions": [
      ".data[] |= @base64d",
      ".data |= map_values(@base64d)"
    ],
    "data": [
      {
        "input": {
          "someattrinbute": "somevalue",
          "data": {
            "SOMENAME": "MTIz",
            "SOMEOTHERNAME": "NDU2"
          }
        },
        "output": {
          "someattrinbute": "somevalue",
          "data": {
            "SOMENAME": "123",
            "SOMEOTHERNAME": "456"
          }
        }
      }
    ],
    "identifier": 61396735
  },
  {
    "context": [
      "Is there the maximum json file size that jq handles.",
      "I build jq 1.6 from github source.",
      "I have tried to handle 288MB json file (in the following command, handwriting_data_info1.json) and got following errors:",
      "jq: src/jv.c:1261: jvp_object_get_slot: Assertion `slot == -1 || (slot >= 0 && slot < jvp_object_size(object))' failed.",
      "FYI, jq filter defintion used above works well for relatively small size json files.",
      "jq can handle arbitrarily long streams of JSON, but if any single JSON item in the stream is too big to fit into memory, the \"streaming parser\" would have to be used.",
      "The \"streaming parser\" is economical with memory but can be noticeably slow and somewhat difficult to use.  Further information about the streaming parser can be found in the jq manual and the [jq FAQ][1].",
      "One way to verify whether jq can manage the input without using the --stream option is to run the `empty` filter, e.g.:",
      "jq empty INPUT.json",
      "The posted error is an assertion error; such errors are normally unrelated to the size of the input entity or entities."
    ],
    "utterance": "Determine if a data file of 288MB can be fully processed without errors and whether there is a configurable input size limit.",
    "expressions": [
      "jq empty handwriting_data_info1.json"
    ],
    "identifier": 61314507
  },
  {
    "context": [
      "I'm calling jq with -r parameter but still in the results, strings are in quotes. How can I get rid of the quotes?",
      "I'm trying to achieve this output\n\n    `TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`\n    `TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`\n\nBasically just convert some json into \"csv\" with backticks as delimiter.",
      "$ jq -r '.[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds] | (..|numbers) |= tostring | join(\"`\") | (\"`\" + . + \"`\")'",
      "`TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`",
      "`TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`"
    ],
    "utterance": "Output selected fields for each application, converting all values to string and joining them with backticks as delimiters, where each result line is wrapped in backticks.",
    "expressions": [
      ".[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds] | (..|numbers) |= tostring | join(\"`\") | (\"`\" + . + \"`\")"
    ],
    "data": [
      {
        "input": {
          "applications": [
            {
              "applicationId": "application_1558485728047_0016",
              "name": "TestCase1_2a4e36be647a6abaf65c48fd1d3c8300",
              "startTime": "2020-04-08T15:49:30.886Z",
              "user": "yyyyyyyyyyyyyyy",
              "pool": "root.users.yyyyyyyy",
              "state": "RUNNING",
              "progress": 10.0,
              "attributes": {},
              "applicationTags": [
                ""
              ],
              "allocatedMemorySeconds": 88789601,
              "allocatedVcoreSeconds": 86708,
              "allocatedMB": 1024,
              "allocatedVCores": 1,
              "runningContainers": 1,
              "mr2AppInformation": {}
            },
            {
              "applicationId": "application_1558480857247_0015",
              "name": "TestCase2_2a6a14ec8365c4836bafd3fdbe647a00",
              "startTime": "2020-04-08T10:43:58.924Z",
              "endTime": "2020-04-08T15:21:32.374Z",
              "user": "xxxxxxx",
              "pool": "root.users.xxxxxxx",
              "state": "FINISHED",
              "progress": 100.0,
              "attributes": {},
              "applicationTags": [
                ""
              ],
              "allocatedMemorySeconds": 5416951035,
              "allocatedVcoreSeconds": 3531555,
              "allocatedMB": 366592,
              "allocatedVCores": 239,
              "runningContainers": 239,
              "mr2AppInformation": {}
            }
          ],
          "warnings": []
        },
        "output": [
          "`TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`",
          "`TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`"
        ]
      }
    ],
    "identifier": 61126318
  },
  {
    "context": [
      "wanted to insert new field in last object of array",
      "Inserting a field to the last element of an array is simple:",
      "jq '.Data.Info[-1] += { \"build\": \"yes\" }'"
    ],
    "utterance": "Add the field build with value yes to the last object in the Info array at Data.Info.",
    "expressions": [
      ".Data.Info[-1] += { \"build\": \"yes\" }"
    ],
    "data": [
      {
        "input": {
          "Data": {
            "Info": [
              {
                "tranID": "1",
                "architecture": "thread_1"
              }
            ]
          }
        },
        "output": {
          "Data": {
            "Info": [
              {
                "tranID": "1",
                "architecture": "thread_1",
                "build": "yes"
              }
            ]
          }
        }
      }
    ],
    "identifier": 61270793
  },
  {
    "context": [
      "I used jq in order to convert them into one file using the command below.",
      "for file in *; do cat $file |jq -c '.[]' >> testNDJSON.json; done",
      "The original JSON structure is following",
      "{\"user_id\":\"user_id_value\",   \"user_properties\": {     \"key\": \"value\", \"key\": \"value\", \"key\": \"value\"    }}",
      "What I would like to get is the same JSON structure I had line by line in the same file.",
      "I don't understand why my command above drops the utmost keys and brackets from JSON.",
      "I'd like to thank @Cyrus and @Antoine Pietri for helpful comments. Learned more about jq tool with this."
    ],
    "utterance": "Write each top-level JSON object from multiple files as a single line in a new file, preserving all keys and structure.",
    "expressions": [
      "jq -c '.' file > output.ndjson"
    ],
    "data": [
      {
        "input": {
          "user_id": "user_id_value",
          "user_properties": {
            "key": "value"
          }
        },
        "output": "{\"user_id\":\"user_id_value\",\"user_properties\":{\"key\":\"value\"}}"
      }
    ],
    "identifier": 61269468
  },
  {
    "context": [
      "I want the entire file returned with the change made so I can post it back to update the config I&#39;m trying to change.",
      "You need to use select on the label selection, otherwise the context changes and you can&#39;t return to the whole object.",
      "(.folders[] | select (.label == '\\\"$folder\\\"')).paused = false",
      "it's cleaner to propagate the variable value as a variable into jq instead of handling or corner cases of quoting yourself:",
      "jq --arg folder \"$folder\" '(.folders[] | select (.label == $folder)).paused = false' \"$f\""
    ],
    "utterance": "Update the value of paused to false for the folder whose label matches the specified value, and return the entire modified data.",
    "expressions": [
      "(.folders[] | select(.label == \"$folder\")).paused = false",
      "jq --arg folder \"$folder\" '(.folders[] | select(.label == $folder)).paused = false'"
    ],
    "identifier": 61269464
  },
  {
    "context": [
      "I have this demo.json file now `if (count == 3)` I want to concatenate the name with the version.",
      "Output:\n    \n    \"ford: 111\"\n    \"ford: 122\"\n    \"bmw: 133\"\n    \"bmw: 144\"\n\nExpected output:\n \n    \"ford: 111\"\n    \"bmw: 144\"\n",
      ".name + \": \" + (.availableVersions[]|select(.count == 3).version|tostring)",
      "\"\\(.name): \\(.availableVersions[]|select(.count == 3).version)\""
    ],
    "utterance": "For each object, extract the name and the version where count equals 3, concatenate them with a colon separator.",
    "expressions": [
      ".name + \": \" + (.availableVersions[] | select(.count == 3).version | tostring)",
      "\"\\(.name): \\(.availableVersions[] | select(.count == 3).version)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 2
              }
            ]
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 133,
                "count": 1
              },
              {
                "version": 144,
                "count": 3
              }
            ]
          }
        ],
        "output": [
          "ford: 111",
          "bmw: 144"
        ]
      }
    ],
    "identifier": 60934812
  },
  {
    "context": [
      "I am trying to loop through each of the objects in the json file and get the `id` name for where `trunk` is `true`.",
      "jq '.[] | select(.trunk == true) | .id' file.json",
      "If .trunk is boolean, you could simplify the `select` parameter to `.trunk`."
    ],
    "utterance": "Return the id of each object where trunk is true.",
    "expressions": [
      ".[] | select(.trunk == true) | .id",
      ".[] | select(.trunk) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "bmw",
            "color": "blue",
            "trunk": true,
            "seat": false
          },
          {
            "id": "merceredes",
            "color": "blue",
            "trunk": false,
            "seat": false
          }
        ],
        "output": [
          "bmw"
        ]
      }
    ],
    "identifier": 60966162
  },
  {
    "context": [
      "The output I'm seeking is an ordered list of keywords sorted by its occurrence. Like this:\n[\n    {\"kw\": \"foo\", \"count\": 3},\n    {\"kw\": \"bar\", \"count\": 2}\n]",
      "If you are referring to sort by the `.count` you can do a ascending sort and reverse\n\n    jq --slurp --compact-output '[ group_by(.kw)[] | {kw: .[0].kw, count: length }] | sort_by(.count) | reverse'"
    ],
    "utterance": "Produce an array of objects, each with a key and its count, sorted in descending order by count.",
    "expressions": [
      "[ group_by(.kw)[] | {kw: .[0].kw, count: length }] | sort_by(.count) | reverse"
    ],
    "data": [
      {
        "input": [
          {
            "kw": "foo",
            "age": 1
          },
          {
            "kw": "foo",
            "age": 1
          },
          {
            "kw": "foo",
            "age": 1
          },
          {
            "kw": "bar",
            "age": 1
          },
          {
            "kw": "bar",
            "age": 1
          }
        ],
        "output": [
          {
            "kw": "foo",
            "count": 3
          },
          {
            "kw": "bar",
            "count": 2
          }
        ]
      }
    ],
    "identifier": 61323243
  },
  {
    "context": [
      "I have a json fragment with an array of keys and a separate array of values. Key 1 should match up to Value 1, etc. I&#39;m trying to reformat with jq but not having much luck.",
      "Original JSON:\r\n```\r\n{\r\n  &quot;result&quot;: {\r\n    &quot;event.KeyValues{}.Key&quot;: [\r\n      &quot;name&quot;,\r\n      &quot;gender&quot;,\r\n      &quot;employee&quot;,\r\n      &quot;email&quot;\r\n    ],\r\n    &quot;event.KeyValues{}.Value&quot;: [\r\n      &quot;tyler&quot;,\r\n      &quot;male&quot;,\r\n      &quot;yes&quot;,\r\n      &quot;tyler@nowhere.com&quot;\r\n    ],\r\n    &quot;foo&quot;: &quot;1&quot;,\r\n    &quot;bar&quot;: &quot;2&quot;\r\n  }\r\n}\r\n```",
      "Desired Output:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;tyler&quot;,\r\n    &quot;gender&quot;: &quot;male&quot;,\r\n    &quot;employee&quot;: &quot;yes&quot;,\r\n    &quot;email&quot;: &quot;tyler@nowhere.com&quot;\r\n}\r\n```",
      "Use `transpose` to pair keys and values. Then you can make an object out of each pair and add them together to get the desired structure.",
      "```\r\n.result\r\n| [.&quot;event.KeyValues{}.Key&quot;, .&quot;event.KeyValues{}.Value&quot;]\r\n| transpose\r\n| map({(.[0]): .[1]})\r\n| add\r\n```"
    ],
    "utterance": "Create an object mapping values from the 'event.KeyValues{}.Key' array to their corresponding values in 'event.KeyValues{}.Value', matching by index.",
    "expressions": [
      ".result\n| [.\"event.KeyValues{}.Key\", .\"event.KeyValues{}.Value\"]\n| transpose\n| map({(.[0]): .[1]})\n| add"
    ],
    "data": [
      {
        "input": {
          "result": {
            "event.KeyValues{}.Key": [
              "name",
              "gender",
              "employee",
              "email"
            ],
            "event.KeyValues{}.Value": [
              "tyler",
              "male",
              "yes",
              "tyler@nowhere.com"
            ],
            "foo": "1",
            "bar": "2"
          }
        },
        "output": {
          "name": "tyler",
          "gender": "male",
          "employee": "yes",
          "email": "tyler@nowhere.com"
        }
      }
    ],
    "identifier": 61415111
  },
  {
    "context": [
      "I wish to extract the value of all the keys named \"value\".",
      "Use [recursive descent](https://stedolan.github.io/jq/manual/#RecursiveDescent:..).\n```\n.. | objects | if has(\"value\") then .value else empty end\n```",
      "Here is a slightly shorter variation ...\n```\n.. | .value? // empty\n```\nExample output (using corrected JSON Sample) \n```\n\"value2\"\n\"value1\"\n```"
    ],
    "utterance": "Extract all values associated with keys named \"value\", regardless of their depth or nesting.",
    "expressions": [
      ".. | objects | if has(\"value\") then .value else empty end",
      ".. | .value? // empty"
    ],
    "data": [
      {
        "input": {
          "k1": "v1",
          "k2": "v2",
          "k3": "v3",
          "k4": {
            "k5": "v5",
            "k6": {
              "k7": "v7",
              "value": "value1"
            }
          },
          "k8": "v8",
          "value": "value2"
        },
        "output": [
          "value2",
          "value1"
        ]
      }
    ],
    "identifier": 60964805
  },
  {
    "context": [
      "I study jq manual and blocked in truncate_stream examples as follows:",
      "$ echo '1' | jq -c '[ 1 |truncate_stream([[0],1],[[1,0],2],[[1,0]],[[1]])]'",
      "[[[0],2],[[0]]]",
      "First, the manual is slightly misleading in that the input value shown (\"Input 1\") is irrelevant. This can be seen e.g. from the fact that the following invocation produces the same array:",
      "$ jq -n -c '[ 1 |truncate_stream([[0],1],[[1,0],2],[[1,0]],[[1]])]'",
      "[[[0],2],[[0]]]",
      "Now, to understand how we get from what I'll call the input stream:",
      "[[0],1], [[1,0],2], [[1,0]], [[1]]",
      "to the output stream:",
      "[[0],2], [[0]]]",
      "The effect of `N | truncate_stream(STREAM)` where N is a non-negative integer is to remove the first N elements of each `path` with the understanding that any item in which path == [] is to be removed.",
      "Thus, removing the first item from each path yields:",
      "[[],1],  [[0],2], [[0]], [[]]",
      "and this then becomes:",
      "[[0],2], [[0]]"
    ],
    "utterance": "Remove the first item from each path in a stream of [path, value] or [path] pairs and output those where the path is non-empty.",
    "expressions": [
      "[1 | truncate_stream([[0],1],[[1,0],2],[[1,0]],[[1]])]"
    ],
    "data": [
      {
        "input": null,
        "output": [
          [
            [
              0
            ],
            2
          ],
          [
            [
              0
            ]
          ]
        ]
      }
    ],
    "identifier": 60926430
  },
  {
    "context": [
      "I have a newline-delimited JSON file. Is it possible to generate a schema using a tool like `jq`? ... Here's the format of the schema I'm aiming for: https://cloud.google.com/bigquery/docs/nested-repeated#example_schema.",
      "I'd like to generate from this: {\"id\":\"1\",...} ...to... [{\"name\": \"id\", \"type\": \"STRING\", \"mode\": \"NULLABLE\"}, ... ]",
      "Here's a simple recursive function that may help if you decide to roll your own:",
      "def schema:\n  def isdate($v):   $v | test(\"[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]\");\n  def array($k;$v): {\"name\":$k,\"type\":\"RECORD\",mode:\"REPEATED\",\"fields\":($v[0] | schema)};\n  def date($k):     {\"name\":$k,\"type\":\"DATE\",  mode:\"NULLABLE\"};\n  def string($k):   {\"name\":$k,\"type\":\"STRING\",mode:\"NULLABLE\"};\n  def item($k;$v):\n     $v | if   type == \"array\"                 then array($k;$v)\n          elif type == \"string\" and isdate($v) then date($k)\n          elif type == \"string\"                then string($k)\n\t  else empty end;\n  [ to_entries[] | item(.key;.value) ]\n;\nschema"
    ],
    "utterance": "Produce a schema in the BigQuery table format, inferring types including nested fields and repeated arrays, such that dates are recognized as DATE and all other strings as STRING, from an example where addresses is a repeated nested record.",
    "expressions": [
      "def schema:\n  def isdate($v):   $v | test(\"[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]\");\n  def array($k;$v): {\"name\":$k,\"type\":\"RECORD\",mode:\"REPEATED\",\"fields\":($v[0] | schema)};\n  def date($k):     {\"name\":$k,\"type\":\"DATE\",  mode:\"NULLABLE\"};\n  def string($k):   {\"name\":$k,\"type\":\"STRING\",mode:\"NULLABLE\"};\n  def item($k;$v):\n     $v | if   type == \"array\"                 then array($k;$v)\n          elif type == \"string\" and isdate($v) then date($k)\n          elif type == \"string\"                then string($k)\n\t  else empty end;\n  [ to_entries[] | item(.key;.value) ]\n;\nschema"
    ],
    "data": [
      {
        "input": {
          "id": "1",
          "first_name": "John",
          "last_name": "Doe",
          "dob": "1968-01-22",
          "addresses": [
            {
              "status": "current",
              "address": "123 First Avenue",
              "city": "Seattle",
              "state": "WA",
              "zip": "11111",
              "numberOfYears": "1"
            },
            {
              "status": "previous",
              "address": "456 Main Street",
              "city": "Portland",
              "state": "OR",
              "zip": "22222",
              "numberOfYears": "5"
            }
          ]
        },
        "output": [
          {
            "name": "id",
            "type": "STRING",
            "mode": "NULLABLE"
          },
          {
            "name": "first_name",
            "type": "STRING",
            "mode": "NULLABLE"
          },
          {
            "name": "last_name",
            "type": "STRING",
            "mode": "NULLABLE"
          },
          {
            "name": "dob",
            "type": "DATE",
            "mode": "NULLABLE"
          },
          {
            "name": "addresses",
            "type": "RECORD",
            "mode": "REPEATED",
            "fields": [
              {
                "name": "status",
                "type": "STRING",
                "mode": "NULLABLE"
              },
              {
                "name": "address",
                "type": "STRING",
                "mode": "NULLABLE"
              },
              {
                "name": "city",
                "type": "STRING",
                "mode": "NULLABLE"
              },
              {
                "name": "state",
                "type": "STRING",
                "mode": "NULLABLE"
              },
              {
                "name": "zip",
                "type": "STRING",
                "mode": "NULLABLE"
              },
              {
                "name": "numberOfYears",
                "type": "STRING",
                "mode": "NULLABLE"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60939071
  },
  {
    "context": [
      "I want to get the IPs that has 'server.sh' value.",
      "jq '.nodes|.[]|select(.:server==\"server.sh\")|.\":ip\"+\":4648\"' test.json",
      "\"192.168.56.30:4648\"",
      "\"192.168.56.31:4648\""
    ],
    "utterance": "Return the IPs with ':4648' appended where the ':server' value equals 'server.sh'.",
    "expressions": [
      ".nodes | .[] | select(.:server == \"server.sh\") | .\":ip\" + \":4648\""
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "test1.local": {
              ":ip": "192.168.56.30",
              ":server": "server.sh",
              ":client": "client.sh"
            },
            "test2.local": {
              ":ip": "192.168.56.31",
              ":server": "server.sh",
              ":client": "client.sh"
            },
            "test3.local": {
              ":ip": "192.168.56.32",
              ":client": "client.sh"
            }
          }
        },
        "output": [
          "192.168.56.30:4648",
          "192.168.56.31:4648"
        ]
      }
    ],
    "identifier": 60983197
  },
  {
    "context": [
      "And the output should if searching for a `node` containg `.foo == \"bar\"` should return\n```\n{\n  \"node\": [\n    {\n      \"node\": {\n        \"foo\": \"bar\"\n      }\n    }\n  ]\n}\n```",
      ".node |= map(select(.node.foo == \"bar\"))",
      "def pv:\n paths as $p\n | getpath($p)\n | . as $v\n | (.node? // empty) | select(.foo == \"bar\")\n | [$p,$v];\n\nreduce pv as [$p,$v] (null; setpath($p; $v))"
    ],
    "utterance": "Extract the subtree that includes the path from the root to a node where .foo equals \"bar\".",
    "expressions": [
      ".node |= map(select(.node.foo == \"bar\"))",
      "def pv:\n paths as $p\n | getpath($p)\n | . as $v\n | (.node? // empty) | select(.foo == \"bar\")\n | [$p,$v];\n\nreduce pv as [$p,$v] (null; setpath($p; $v))"
    ],
    "data": [
      {
        "input": {
          "node": [
            {
              "node": {
                "foo": "bar"
              }
            },
            {
              "node": {
                "foo": "foo"
              }
            }
          ]
        },
        "output": {
          "node": [
            {
              "node": {
                "foo": "bar"
              }
            }
          ]
        }
      }
    ],
    "identifier": 60990532
  },
  {
    "context": [
      "I need to aggregate the results, match the values to the number of requests and print out the result in descending Order.",
      "How do I combine the results of the same accounts before printing it out? The results also need to be in descending order of number of requests.",
      "the following produces the desired output:\n```\njq -nr '\n  [inputs | .results[] | map( { (.field) : .value} ) | add] \n  | group_by(.AccountId)\n  | map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])\n  | sort_by(.[1]) | reverse\n  | .[]\n  | join(\" : \")\n' \n```"
    ],
    "utterance": "Aggregate the total number of requests per AccountId from multiple files, combine results by AccountId, and output the totals in descending order.",
    "expressions": [
      "[inputs | .results[] | map( { (.field) : .value} ) | add] \n| group_by(.AccountId)\n| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])\n| sort_by(.[1]) | reverse\n| .[]\n| join(\" : \")"
    ],
    "data": [
      {
        "input": [
          {
            "results": [
              [
                {
                  "field": "AccountId",
                  "value": "11352"
                },
                {
                  "field": "number_of_requests",
                  "value": "241398"
                }
              ],
              [
                {
                  "field": "AccountId",
                  "value": "74923"
                },
                {
                  "field": "number_of_requests",
                  "value": "238566"
                }
              ]
            ],
            "statistics": {
              "recordsMatched": 502870.0,
              "recordsScanned": 165908292.0,
              "bytesScanned": 744173091162.0
            },
            "status": "Complete"
          },
          {
            "results": [
              [
                {
                  "field": "AccountId",
                  "value": "11352"
                },
                {
                  "field": "number_of_requests",
                  "value": "185096"
                }
              ]
            ],
            "statistics": {
              "recordsMatched": 502870.0,
              "recordsScanned": 165908292.0,
              "bytesScanned": 744173091162.0
            },
            "status": "Complete"
          }
        ],
        "output": [
          "11352 : 426494",
          "74923 : 238566"
        ]
      }
    ],
    "identifier": 61331916
  },
  {
    "context": [
      "I have a directory of about 100 JSON files, each an array of 100 simple records, that I want to concatenate into one file for inclusion as static data in an app",
      "jq -s '[0] + .[1]' file1.json file2.json > output.json",
      "jq -s 'reduce .[] as $item ({}; . * $item)' json_files/* > output.json",
      "jq: error (at json_files/categories-11-20.json:0): object ({}) and array ([{\"id\":1153...) cannot be multiplied",
      "The simplest and perfectly reasonable approach would be to use the -s command-line option and `add` along the following lines:",
      "jq -s add json_files/* "
    ],
    "utterance": "Concatenate arrays from all files in a directory into a single array containing all records.",
    "expressions": [
      "jq -s add json_files/*"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 11531,
              "title": "category 1",
              "count": 5
            },
            {
              "id": 11532,
              "title": "category 2",
              "count": 5
            }
          ],
          [
            {
              "id": 11533,
              "title": "category 3",
              "count": 4
            }
          ]
        ],
        "output": [
          {
            "id": 11531,
            "title": "category 1",
            "count": 5
          },
          {
            "id": 11532,
            "title": "category 2",
            "count": 5
          },
          {
            "id": 11533,
            "title": "category 3",
            "count": 4
          }
        ]
      }
    ],
    "identifier": 61391200
  },
  {
    "context": [
      "I am trying to parse a very large file which consists of JSON objects like this:",
      "Now I also have a very big list of ID's that I want to extract from the file, if they are there.",
      "my list of id's is very long too (100k or so).",
      "My question is, given a big amount of arguments for the filter, how would I proceed with putting them into my jq command?",
      "Assuming ids.json contains a lising of the ids as JSON strings:",
      "\"1\"",
      "\"2\"",
      "\"3\"",
      "then one could write:",
      "< objects.json jq -c -n --slurpfile ids ids.json '",
      "  inputs | . as $in | select( $ids | index($in.id))'"
    ],
    "utterance": "Filter input data to include only objects whose 'id' field matches any id from a large list provided in an external file.",
    "expressions": [
      "inputs | . as $in | select($ids | index($in.id))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "title": "foo",
            "year": 2001
          },
          {
            "id": "2",
            "title": "bar",
            "year": 2002
          },
          {
            "id": "4",
            "title": "baz",
            "year": 2003
          }
        ],
        "output": [
          {
            "id": "1",
            "title": "foo",
            "year": 2001
          },
          {
            "id": "2",
            "title": "bar",
            "year": 2002
          }
        ]
      }
    ],
    "identifier": 61412842
  },
  {
    "context": [
      "Using 'jq' I want to change all the dates from eg. 19731013 (string) to a 1973-10-13",
      "jq -r '[].Start_Date |= \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\" | [].Function_Start_Date |= \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\" | [].Date_of_Birth|=\"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\"' employees.json > test.json",
      "$ jq '[].Start_Date | \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\"' file",
      "jq '[].Start_Date | capture(\"(?<x>[0-9]{4})(?<y>[0-9]{2})(?<z>[0-9]{2})\") | join(\"-\")'"
    ],
    "utterance": "Reformat all date fields containing an 8-digit string in the form YYYYMMDD to use dashes as YYYY-MM-DD.",
    "expressions": [
      ".[].Start_Date |= \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\" | .[].Function_Start_Date |= \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\" | .[].Date_of_Birth |= \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\"",
      ".[].Start_Date | \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8])\"",
      ".[].Start_Date | capture(\"(?<x>[0-9]{4})(?<y>[0-9]{2})(?<z>[0-9]{2})\") | join(\"-\")"
    ],
    "data": [
      {
        "input": [
          {
            "Mail": "john@example.com",
            "Name": "Smith",
            "Employee_Number": "000555",
            "First_Name": "John",
            "Company": "ACME",
            "Department": null,
            "Employment_Status": "Retiree",
            "Start_Date": "19770516",
            "Function_Start_Date": "19770516",
            "Group_Phone": "",
            "Job_Title": "Operations Manager Warehousing",
            "Sub_Group": "Exempts",
            "Location": "Tibuktu",
            "Organizational_Unit": null,
            "Date_of_Birth": "19560719",
            "Gender": "1"
          },
          {
            "Mail": "mary@example.com",
            "Name": "Smith",
            "Employee_Number": "000777",
            "First_Name": "Mary",
            "Company": "ACME",
            "Department": null,
            "Employment_Status": "Retiree",
            "Start_Date": "19770516",
            "Function_Start_Date": "19770516",
            "Group_Phone": "",
            "Job_Title": "Manager",
            "Sub_Group": "Exempts",
            "Location": "Tibuktu",
            "Organizational_Unit": null,
            "Date_of_Birth": "19560719",
            "Gender": "2"
          }
        ],
        "output": [
          {
            "Mail": "john@example.com",
            "Name": "Smith",
            "Employee_Number": "000555",
            "First_Name": "John",
            "Company": "ACME",
            "Department": null,
            "Employment_Status": "Retiree",
            "Start_Date": "1977-05-16",
            "Function_Start_Date": "1977-05-16",
            "Group_Phone": "",
            "Job_Title": "Operations Manager Warehousing",
            "Sub_Group": "Exempts",
            "Location": "Tibuktu",
            "Organizational_Unit": null,
            "Date_of_Birth": "1956-07-19",
            "Gender": "1"
          },
          {
            "Mail": "mary@example.com",
            "Name": "Smith",
            "Employee_Number": "000777",
            "First_Name": "Mary",
            "Company": "ACME",
            "Department": null,
            "Employment_Status": "Retiree",
            "Start_Date": "1977-05-16",
            "Function_Start_Date": "1977-05-16",
            "Group_Phone": "",
            "Job_Title": "Manager",
            "Sub_Group": "Exempts",
            "Location": "Tibuktu",
            "Organizational_Unit": null,
            "Date_of_Birth": "1956-07-19",
            "Gender": "2"
          }
        ]
      }
    ],
    "identifier": 61012699
  },
  {
    "context": [
      "I would need a plain list of the items \"useful\" and \"usefulAsWell\". I don't know if more useful items will be added later on, but I know which items are waste and want them included instead of just listing the useful ones.",
      "With the following command I already got a list, but it still contains format characters like [],\"",
      "With the following command I get a nice list, but it unfortunately contains the waste:",
      "When trying to add the deletion part, I get an error message:",
      "The description of the problem contains an inconsistency (a typo?), but it looks like you're after:",
      ".stuff | del(.waste, .moreWaste) | .[][]"
    ],
    "utterance": "Get a plain list of all items in the object except those belonging to the waste and moreWaste keys.",
    "expressions": [
      ".stuff | del(.waste, .moreWaste) | .[][]"
    ],
    "data": [
      {
        "input": {
          "stuff": {
            "usfull": [
              "aa",
              "bb",
              "cc",
              "dd"
            ],
            "usefulAsWell": [
              "ab",
              "cd",
              "ef",
              "gh"
            ],
            "waste": [
              "12",
              "34",
              "56"
            ],
            "moreWaste": [
              "78"
            ]
          }
        },
        "output": [
          "aa",
          "bb",
          "cc",
          "dd",
          "ab",
          "cd",
          "ef",
          "gh"
        ]
      }
    ],
    "identifier": 61361586
  },
  {
    "context": [
      "I need to obtain all-values individually by given word `dev-cds` and not all the name `dev-cds-5c97cf7f78-sw6b9`.",
      "You should first iterate over the result array. Check if the pod inside, metric object has the value that contains \"dev-cds\".",
      ".data.result[] | if .metric.pod | contains(\"dev-cds\") then . else empty end"
    ],
    "utterance": "Extract elements where the metric.pod value contains the string 'dev-cds'.",
    "expressions": [
      ".data.result[] | select(.metric.pod | contains(\"dev-cds\"))"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "resultType": "matrix",
            "result": [
              {
                "metric": {
                  "pod": "dev-cds-5c97cf7f78-sw6b9"
                },
                "values": [
                  [
                    1588204800,
                    "0.3561394483796914"
                  ],
                  [
                    1588215600,
                    "0.3607968456046861"
                  ],
                  [
                    1588226400,
                    "0.3813882532417868"
                  ],
                  [
                    1588237200,
                    "0.6264355815408573"
                  ]
                ]
              },
              {
                "metric": {
                  "pod": "uat-cds-66ccc9685-b5tvh"
                },
                "values": [
                  [
                    1588204800,
                    "0.9969746974696218"
                  ],
                  [
                    1588215600,
                    "0.7400881057270005"
                  ],
                  [
                    1588226400,
                    "1.2298959318837195"
                  ],
                  [
                    1588237200,
                    "0.9482296838254507"
                  ]
                ]
              }
            ]
          }
        },
        "output": {
          "metric": {
            "pod": "dev-cds-5c97cf7f78-sw6b9"
          },
          "values": [
            [
              1588204800,
              "0.3561394483796914"
            ],
            [
              1588215600,
              "0.3607968456046861"
            ],
            [
              1588226400,
              "0.3813882532417868"
            ],
            [
              1588237200,
              "0.6264355815408573"
            ]
          ]
        }
      }
    ],
    "identifier": 61520989
  },
  {
    "context": [
      "How do I use something like `pow`?",
      "It&#39;s simple, just separate function arguments by `;`:",
      "echo '{\"a\": 10.12}' | jq '. | pow(.a;.a)'",
      "20051775181.748566"
    ],
    "utterance": "Calculate the result of raising the value at key `a` to the power of itself.",
    "expressions": [
      "pow(.a;.a)"
    ],
    "data": [
      {
        "input": {
          "a": 10.12
        },
        "output": 20051775181.748566
      }
    ],
    "identifier": 61390589
  },
  {
    "context": [
      "Given an invalid JSON string such as: `{ foo: bar }` is it possible to get `jq` to process and format correctly as `{ &quot;foo&quot;: &quot;bar&quot; }`",
      "No, or at least not without complex programming, though jq can handle objects with unquoted key names, e.g. `{foo: &quot;bar&quot;}`.",
      "(Hint: read the quasi-JSON as a jq program.)"
    ],
    "utterance": "Convert input in the form {foo: \"bar\"} to a properly formatted object with quoted keys and string values.",
    "expressions": [
      "jq '.'"
    ],
    "data": [
      {
        "input": "{foo: \"bar\"}",
        "output": {
          "foo": "bar"
        }
      }
    ],
    "identifier": 61202588
  },
  {
    "context": [
      "I would like to append n-times the object within the \"actions\" array to the end of it, creating n+1 total objects.",
      "Expected output if n=2:",
      "You can just use a `reduce()` function with `range()` together to create the index to include the object at.",
      "jq --arg n 2 'reduce range(0, ($n|tonumber)) as $d (.; .actions[$d+1] += .actions[0] )'"
    ],
    "utterance": "Append the first object in the 'actions' array to the end of the array n times, so that the array contains n+1 copies of that object.",
    "expressions": [
      "jq --arg n 2 'reduce range(0, ($n|tonumber)) as $d (.; .actions[$d+1] += .actions[0] )'"
    ],
    "data": [
      {
        "input": {
          "actions": [
            {
              "values": "test",
              "features": [
                {
                  "v1": 100,
                  "v2": {
                    "dates": [
                      "2020-04-08 06:58:26",
                      "2020-04-08 06:58:26"
                    ]
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "actions": [
            {
              "values": "test",
              "features": [
                {
                  "v1": 100,
                  "v2": {
                    "dates": [
                      "2020-04-08 06:58:26",
                      "2020-04-08 06:58:26"
                    ]
                  }
                }
              ]
            },
            {
              "values": "test",
              "features": [
                {
                  "v1": 100,
                  "v2": {
                    "dates": [
                      "2020-04-08 06:58:26",
                      "2020-04-08 06:58:26"
                    ]
                  }
                }
              ]
            },
            {
              "values": "test",
              "features": [
                {
                  "v1": 100,
                  "v2": {
                    "dates": [
                      "2020-04-08 06:58:26",
                      "2020-04-08 06:58:26"
                    ]
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 61520771
  },
  {
    "context": [
      "I was wondering how I can use jq in order to find people who graduated from Georgia Tech with a non empty list of students? As in, I want to find all students who graduated from Georgia Tech who went on to advise students themselves.",
      "You can combine the conditions with `and`\n```\n.nodes |= map( \n   select( (.school == \"Georgia Tech\") and (.students | length > 0) ) \n)\n```"
    ],
    "utterance": "Find all records where school is \"Georgia Tech\" and the students list is not empty.",
    "expressions": [
      ".nodes |= map( select( (.school == \"Georgia Tech\") and (.students | length > 0) ) )"
    ],
    "data": [
      {
        "input": {
          "nodes": [
            {
              "students": [
                2,
                3
              ],
              "advisors": [],
              "name": "Person 1",
              "school": "Georgia Tech",
              "id": 1
            },
            {
              "students": [],
              "advisors": [
                1
              ],
              "name": "Person 2",
              "school": "Georgia Tech",
              "id": 2
            },
            {
              "students": [],
              "advisors": [
                1
              ],
              "name": "Person 3",
              "school": "Georgia Tech",
              "id": 3
            }
          ]
        },
        "output": {
          "nodes": [
            {
              "students": [
                2,
                3
              ],
              "advisors": [],
              "name": "Person 1",
              "school": "Georgia Tech",
              "id": 1
            }
          ]
        }
      }
    ],
    "identifier": 61298904
  },
  {
    "context": [
      "I am trying to just print The \"AccountID\" sorted by \"Requests\" in ZSH using jq.",
      "The projectd output requirement is just the Account ID vs Request Number.",
      "5577497 has 51900 requests\n5177497 has 50900 requests\npro has 251 requests",
      "[inputs | .results[] | map( { (.field) : .value} ) | add]",
      "jq -S '.results[] | map( { (.field) : .value} ) | add' query-results-aggregate \\ | jq -s -c 'group_by(.number_of_requests) | .[]'"
    ],
    "utterance": "Print AccountID and corresponding Requests, sorted by Requests in descending order.",
    "expressions": [
      "[inputs | .results[] | map({(.field): .value}) | add] | sort_by(.Requests | tonumber) | reverse | .[] | \"\u001b[38;5;15m\u001b[1m\u001b[43m\u001b[4m\u001b[5m\u001b[46m\u001b[3m\u001b[7m\u001b[1m\u001b[0m\\(.AccountID) has \\(.Requests) requests\"",
      "[inputs | .results[] | map({(.field): .value}) | add] | sort_by(.Requests | tonumber) | reverse | .[] | \"\\(.AccountID) has \\(.Requests) requests\""
    ],
    "data": [
      {
        "input": [
          {
            "results": [
              [
                {
                  "field": "AccountID",
                  "value": "5177497"
                },
                {
                  "field": "Requests",
                  "value": "50900"
                }
              ],
              [
                {
                  "field": "AccountID",
                  "value": "pro"
                },
                {
                  "field": "Requests",
                  "value": "251"
                }
              ]
            ],
            "statistics": {
              "Matched": 51498,
              "Scanned": 8673577,
              "ScannedByte": 27240081400.0
            },
            "status": "HOLD"
          },
          {
            "results": [
              [
                {
                  "field": "AccountID",
                  "value": "5577497"
                },
                {
                  "field": "Requests",
                  "value": "51900"
                }
              ]
            ],
            "statistics": {
              "Matched": 51498,
              "Scanned": 8673577,
              "ScannedByte": 27240081400.0
            },
            "status": "HOLD"
          }
        ],
        "output": [
          "5577497 has 51900 requests",
          "5177497 has 50900 requests",
          "pro has 251 requests"
        ]
      }
    ],
    "identifier": 61197817
  },
  {
    "context": [
      "curl -H \"Authorization: token $github_personal_access_token\" \"$file_url\"  | \r\n  jq -r '.content' | base64 -d > output.json",
      "but I just want the raw file content, not the metadata.",
      "the output.json looks like:\r\n\r\n    {\r\n      ...\r\n      \"content\": \"ewogICJuYW1lIjogImxpdmUtbXV0ZXgiLAogICJ2ZXJzaW9uIjogIjAuMi4y\\nNCIsCiAgImRlc2NyaXB0aW9uIjogIlNpbXBsZSBtdXRleCB0aGF0IHVzZXMg\\nYSBUQ1Agc2VydmVyOyB1c2VmdWwgaWYgeW91IGNhbm5vdCBpbnN0YWxsIFJl\\nZGlzLCBldGMuIiwKICAibWFpbiI6ICJkaXN0L21haW4uanMiLAogICJ0eXBp\\nbmdzIjogImRpc3QvbWFpbi5kLnRzIiwKICAidHlwZXMiOiAiZGlzdC9tYWlu\\nLmQudHMiLAogICJiaW4iOiB7CiAgICAibG14X2FjcXVpcmVfbG9jayI6ICJh\\nc3NldHMvY2xpL2FjcXVpcmUuanMiLAogICAgImxteF9yZWxlYXNlX2xvY2si\\nOiAiYXNzZXRzL2NsaS9yZWxlYXNlLmpzIiwKICAgICJsbXhfaW5zcGVjdF9i\\ncm9rZXIiOiAiYXNzZXRzL2NsaS9pbnNwZWN0LmpzIiwKICAgICJsbXhfbGF1\\bmNoX2Jyb2tlciI6ICJhc3NldHMvY2xpL3N0YXJ0LXNlcnZlci5qcyIsCiAg\\nICAibG14X3N0YXJ0X3NlcnZlciI6ICJhc3NldHMvY2xpL3N0YXJ0LXNlcnZl\\nci5qcyIsCiAgICAibG14X2xzIjogImFzc2V0cy9jbGkvbHMuanMiLAogICAg\\nImxteCI6ICJhc3NldHMvbG14LnNoIgogIH0sCiAgInNjcmlwdHMiOiB7CiAg\\nICAidGVzdCI6ICIuL3NjcmlwdHMvdGVzdC5zaCIsCiAgICAicG9zdGluc3Rh\\nbGwiOiAiLi9hc3NldHMvcG9zdGluc3RhbGwuc2giCiAgfSwKICAicjJnIjog\\newogICAgInRlc3QiOiAiLi90ZXN0L3NldHVwLXRlc3Quc2ggJiYgc3VtYW4g\\nLS1kZWZhdWx0IgogIH0sCiAgInJlcG9zaXRvcnkiOiB7CiAgICAidHlwZSI6\\nICJnaXQiLAogICAgInVybCI6ICJnaXQraHR0cHM6Ly9naXRodWIuY29tL09S\\nRVNvZnR3YXJlL2xpdmUtbXV0ZXguZ2l0IgogIH0sCiAgImF1dGhvciI6ICJP\\nbGVnemFuZHIgVkQiLAogICJsaWNlbnNlIjogIk1JVCIsCiAgImJ1Z3MiOiB7\\nCiAgICAidXJsIjogImh0dHBzOi8vZ2l0aHViLmNvbS9PUkVTb2Z0d2FyZS9s\\naXZlLW11dGV4L2lzc3VlcyIKICB9LAogICJob21lcGFnZSI6ICJodHRwczov\\nL2dpdGh1Yi5jb20vT1JFU29mdHdhcmUvbGl2ZS1tdXRleCNyZWFkbWUiLAog\\nICJkZXBlbmRlbmNpZXMiOiB7CiAgICAiQG9yZXNvZnR3YXJlL2pzb24tc3Ry\\nZWFtLXBhcnNlciI6ICIwLjAuMTI0IiwKICAgICJAb3Jlc29mdHdhcmUvbGlu\\na2VkLXF1ZXVlIjogIjAuMS4xMDYiLAogICAgImNoYWxrIjogIl4yLjQuMiIs\\nCiAgICAidGNwLXBpbmciOiAiXjAuMS4xIiwKICAgICJ1dWlkIjogIl4zLjMu\\nMiIKICB9LAogICJkZXZEZXBlbmRlbmNpZXMiOiB7CiAgICAiQHR5cGVzL25v\\nZGUiOiAiXjEwLjEuMiIsCiAgICAiQHR5cGVzL3RjcC1waW5nIjogIl4wLjEu\\nMCIsCiAgICAiQHR5cGVzL3V1aWQiOiAiXjMuNC4zIgogIH0KfQo=\\n\",",
      "the biggest problem is I don't have a valid access_token in hand, and I can get an access token to download the file from the download_url, but that requires extra scripting steps.",
      "curl -H \"Authorization: token $github_personal_access_token\" \"$file_url\"  | \r\n  jq -r '.content' | base64 -d > output.json"
    ],
    "utterance": "Extract the base64-decoded value of the 'content' field from an object and output it directly.",
    "expressions": [
      ".content | @base64d",
      ".content | @base64d\n",
      ".content | @base64d\r",
      ".content | @base64d\r\n",
      ".[\"content\"] | @base64d"
    ],
    "data": [
      {
        "input": {
          "name": "package.json",
          "path": "package.json",
          "sha": "6a2d55983bb641ff217d822d8e60dbb6c8f85ea3",
          "size": 1343,
          "url": "https://api.github.com/repos/ORESoftware/live-mutex/contents/package.json?ref=master",
          "html_url": "https://github.com/ORESoftware/live-mutex/blob/master/package.json",
          "git_url": "https://api.github.com/repos/ORESoftware/live-mutex/git/blobs/6a2d55983bb641ff217d822d8e60dbb6c8f85ea3",
          "download_url": "https://raw.githubusercontent.com/ORESoftware/live-mutex/master/package.json",
          "type": "file",
          "content": "ewogICJuYW1lIjogImxpdmUtbXV0ZXgiLAogICJ2ZXJzaW9uIjogIjAuMi4yMjQiLAogICJkZXNjcmlwdGlvbiI6ICJTaW1wbGUgbXV0ZXggdGhhdCB1c2VzIGEgVENQIHNlcnZlcjsgdXNlZnVsIGlmIHlvdSBjYW5ub3QgaW5zdGFsbCBSZWRpcywgZXRjLiIsCiAgIm1haW4iOiAiZGlzdC9tYWluLmpzIiwKICAidHlwaW5ncyI6ICJkaXN0L21haW4uZC50cyIsCiAgInR5cGVzIjogImRpc3QvbWFpbi5kLnRzIiwKICAiYmluIjogewogICAgImxteF9hY3F1aXJlX2xvY2siOiAiYXNzZXRzL2NsaS9hY3F1aXJlLmpzIiwKICAgICJsbXhfcmVsZWFzZV9sb2NrIjogImFzc2V0cy9jbGkvcmVsZWFzZS5qcyIsCiAgICAibG14X2luc3BlY3RfYnJva2VyIjogImFzc2V0cy9jbGkvaW5zcGVjdC5qcyIsCiAgICAibG14X2xhdW5jaF9icm9rZXIiOiAiYXNzZXRzL2NsaS9zdGFydC1zZXJ2ZXIuanMiLAogICAgImxteF9zdGFydF9zZXJ2ZXIiOiAiYXNzZXRzL2NsaS9zdGFydC1zZXJ2ZXIuanMiLAogICAgImxteF9scyI6ICJhc3NldHMvY2xpL2xzLmpzIiwKICAgICJsbXgiOiAiYXNzZXRzL2xteC5zaCIKICB9LAogICJzY3JpcHRzIjogewogICAgInRlc3QiOiAiLi9zY3JpcHRzL3Rlc3Quc2giLAogICAgInBvc3RpbnN0YWxsIjogIi4vYXNzZXRzL3Bvc3RpbnN0YWxsLnNoIgogIH0sCiAgInIyZyI6IHsKICAgICJ0ZXN0IjogIi4vdGVzdC9zZXR1cC10ZXN0LnNoICYmIHN1bWFuIC0tZGVmYXVsdCIKICB9LAogICJyZXBvc2l0b3J5IjogewogICAgInR5cGUiOiAiZ2l0IiwKICAgICJ1cmwiOiJnaXQraHR0cHM6Ly9naXRodWIuY29tL09SRVNvZnR3YXJlL2xpdmUtbXV0ZXguZ2l0IgogIH0sCiAgImF1dGhvciI6ICJPbGVnemFuZHIgVkQiLAogICJsaWNlbnNlIjogIk1JVCIsCiAgImJ1Z3MiOiB7CiAgICAidXJsIjogImh0dHBzOi8vZ2l0aHViLmNvbS9PUkVTb2Z0d2FyZS9saXZlLW11dGV4L2lzc3VlcyIKICB9LAogICJob21lcGFnZSI6ICJodHRwczovL2dpdGh1Yi5jb20vT1JFU29mdHdhcmUvbGl2ZS1tdXRleCNyZWFkbWUiLAogICJkZXBlbmRlbmNpZXMiOiB7CiAgICAiQG9yZXNvZnR3YXJlL2pzb24tc3RyZWFtLXBhcnNlciI6ICIwLjAuMTI0IiwKICAgICJAb3Jlc29mdHdhcmUvbGlua2VkLXF1ZXVlIjogIjAuMS4xMDYiLAogICAgImNoYWxrIjogIl4yLjQuMiIsCiAgICAidGNwLXBpbmciOiAiXjAuMS4xIiwKICAgICJ1dWlkIjogIl4zLjMuMiIKICB9LAogICJkZXZEZXBlbmRlbmNpZXMiOiB7CiAgICAiQHR5cGVzL25vZGUiOiAiXjEwLjEuMiIsCiAgICAiQHR5cGVzL3RjcC1waW5nIjogIl4wLjEuMCIsCiAgICAiQHR5cGVzL3V1aWQiOiAiXjMuNC4zIgogIH0KfQo=",
          "encoding": "base64",
          "_links": {
            "self": "https://api.github.com/repos/ORESoftware/live-mutex/contents/package.json?ref=master",
            "git": "https://api.github.com/repos/ORESoftware/live-mutex/git/blobs/6a2d55983bb641ff217d822d8e60dbb6c8f85ea3",
            "html": "https://github.com/ORESoftware/live-mutex/blob/master/package.json"
          }
        }
      }
    ],
    "identifier": 61520063
  },
  {
    "context": [
      "I need to extract the `codec_name` of the second video stream (artwork) of a video file.",
      "You need to make the `select()` after `.streams`",
      ".streams[] | select(.codec_type==\"video\").codec_name",
      "For selecting a object at a specific index, use the standard array notation `.[0]`, `.[1]`",
      "[ .streams[] | select(.codec_type==\"video\") ][1] | .codec_name"
    ],
    "utterance": "Extract the codec_name of the second stream where codec_type is video.",
    "expressions": [
      "[ .streams[] | select(.codec_type==\"video\") ][1] | .codec_name"
    ],
    "data": [
      {
        "input": {
          "streams": [
            {
              "index": 0,
              "codec_name": "h264",
              "codec_type": "video"
            },
            {
              "index": 1,
              "codec_name": "aac",
              "codec_type": "audio"
            },
            {
              "index": 2,
              "codec_name": "mjpeg",
              "codec_type": "video"
            }
          ]
        },
        "output": "mjpeg"
      }
    ],
    "identifier": 61475413
  },
  {
    "context": [
      "jq -r '.[] | \"\\(.id) \\(.age) \\(.inSchool) \\(.name)\"' fixed.json | \\",
      "For a real JSON file, like:\n[\n    {\n        \"id\": 1,\n        \"name\": \"Amit\",\n        \"age\": 18,\n        \"inSchool\": 1\n    },\n    {\n        \"id\": 2,\n        \"name\": \"Sunil\",\n        \"age\": 21,\n        \"inSchool\": 0\n    },\n    {\n        \"id\": 3,\n        \"name\": \"Anil\",\n        \"age\": 17,\n        \"inSchool\": 1\n    }\n]"
    ],
    "utterance": "Extract each object's id, age, inSchool status, and name, formatting them in a single line per object: 'id age inSchool name'.",
    "expressions": [
      ".[] | \"\u001b[0m\\(.id) \\(.age) \\(.inSchool) \\(.name)\""
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "Amit",
            "age": 18,
            "inSchool": 1
          },
          {
            "id": 2,
            "name": "Sunil",
            "age": 21,
            "inSchool": 0
          },
          {
            "id": 3,
            "name": "Anil",
            "age": 17,
            "inSchool": 1
          }
        ],
        "output": [
          "1 18 1 Amit",
          "2 21 0 Sunil",
          "3 17 1 Anil"
        ]
      }
    ],
    "identifier": 61181204
  },
  {
    "context": [
      "I need to get the username and email address for each user in the JSON below.",
      "each property of the user is stored in a dictionary of name value pairs. The number of name-value pairs is not fixed and the order of the email address property is not fixed either.",
      "I want to extract each user and their email address like so:",
      "{\r\n  \"Username\": \"test\",\r\n  \"email\": \"test@gmail.com\"\r\n},\r\n{\r\n  \"Username\": \"test2\",\r\n  \"email\": \"test2@gmail.com\"\r\n}",
      ".Users[] | { Username, email : .Attributes[].Value } | select(.email | contains(\"@\"))"
    ],
    "utterance": "Extract each user's Username and their email address where the email is found in Attributes as a name-value pair and may appear in any order.",
    "expressions": [
      ".Users[] | { Username, email: (.Attributes[] | select(.Name == \"email\") | .Value) }"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "Username": "test",
              "Attributes": [
                {
                  "Name": "department",
                  "Value": "department 1"
                },
                {
                  "Name": "random attribute",
                  "Value": "random attribute value"
                },
                {
                  "Name": "email",
                  "Value": "test@gmail.com"
                }
              ]
            },
            {
              "Username": "test2",
              "Attributes": [
                {
                  "Name": "email",
                  "Value": "test2@gmail.com"
                },
                {
                  "Name": "department",
                  "Value": "department 1"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "Username": "test",
            "email": "test@gmail.com"
          },
          {
            "Username": "test2",
            "email": "test2@gmail.com"
          }
        ]
      }
    ],
    "identifier": 61518353
  },
  {
    "context": [
      "So my question is how I can get just the last 15 element and the rest deleted?",
      "Assuming I am understanding you correctly, you can use the jq range operator:",
      "jq '.[-15:]' historique.json",
      "To output just the last 15 elements of an array, use slice syntax.",
      "jq '.[-15:]' historique.json"
    ],
    "utterance": "Return only the last 15 elements from the array; discard all earlier elements.",
    "expressions": [
      ".[-15:]"
    ],
    "data": [
      {
        "input": [
          {
            "PTF_INSTALL_DATE": "2020-03-31 09:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_batch_API",
                "CHECKED": "api_batch_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          },
          {
            "PTF_INSTALL_DATE": "2020-03-31 10:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_back_API",
                "CHECKED": "api_back_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          },
          {
            "PTF_INSTALL_DATE": "2020-03-31 11:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_ihm_API",
                "CHECKED": "api_ihm_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          }
        ],
        "output": [
          {
            "PTF_INSTALL_DATE": "2020-03-31 09:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_batch_API",
                "CHECKED": "api_batch_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          },
          {
            "PTF_INSTALL_DATE": "2020-03-31 10:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_back_API",
                "CHECKED": "api_back_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          },
          {
            "PTF_INSTALL_DATE": "2020-03-31 11:12:10",
            "PTF_CONTENT": [
              {
                "NAME": "api_ihm_API",
                "CHECKED": "api_ihm_NOT_SELECTED",
                "VERSION": "G02R00C13_c14",
                "CONFIG_FILE": ""
              }
            ]
          }
        ]
      }
    ],
    "identifier": 60958984
  },
  {
    "context": [
      "From the command line, I want to return the value of `status` from the item whose `name` is \"server\" (the position varies so it can't just be called with array index 0).",
      "You can use [tag:jq] at the command-line without any Node entanglements:",
      "$ jq -r '.[] | select(.name == \"server\") | .status' input.json",
      "$ online"
    ],
    "utterance": "Retrieve the status value of the object whose name is \"server\".",
    "expressions": [
      ".[] | select(.name == \"server\") | .status"
    ],
    "data": [
      {
        "input": [
          {
            "pid": 0,
            "name": "server",
            "status": "online"
          },
          {
            "pid": 1,
            "name": "server2",
            "status": "stopped"
          }
        ],
        "output": "online"
      }
    ],
    "identifier": 60922454
  },
  {
    "context": [
      "I want to append some keys and values and object before the jq output and then at the end append auth and ID. How can I do that?",
      "But I want to output like this which includes jsonrpc, methods, params, filter and then the host array needs to be added and in the end append auth and id.",
      "jq -n --argjson hosts '[\"host001\", \"host002\", \"host003\"]' \\\n       '{ \n           jsonrpc: \"2.0\", \n           method: \"host.get\", \n           params: {filter: {\"hostid\": $hosts}}, \n           auth: \"038e1d7b1735c6a5436ee9eae095879e\", \n           id: 1  \n        }'"
    ],
    "utterance": "Construct an object with keys 'jsonrpc', 'method', 'params.filter.hostid' as an array of specific values, and append 'auth' and 'id' at the end.",
    "expressions": [
      "jq -n --argjson hosts '[\"host001\", \"host002\", \"host003\"]' '{jsonrpc: \"2.0\", method: \"host.get\", params: {filter: {\"hostid\": $hosts}}, auth: \"038e1d7b1735c6a5436ee9eae095879e\", id: 1}'"
    ],
    "data": [
      {
        "input": [
          "host001",
          "host002",
          "host003"
        ],
        "output": {
          "jsonrpc": "2.0",
          "method": "host.get",
          "params": {
            "filter": {
              "hostid": [
                "host001",
                "host002",
                "host003"
              ]
            }
          },
          "auth": "038e1d7b1735c6a5436ee9eae095879e",
          "id": 1
        }
      }
    ],
    "identifier": 61517699
  },
  {
    "context": [
      "I want to output a string where every two numbers are joined as a pair with a \",\", and then separate these pairs with spaces as below.",
      "First, join x-y pairs by commas, then join resulting strings by spaces.",
      ".normalizedVertices | map(\"\\(if has(\"x\") then .x * 320 else 0 end),\\(.y * 240)\") | join(\" \")"
    ],
    "utterance": "Produce a string of bounding box coordinates where each x and y value (with x defaulting to 0 if missing) is multiplied by 320 and 240 respectively, joined as comma-separated pairs, and all pairs are space-separated.",
    "expressions": [
      ".normalizedVertices | map(\"\\(if has(\"x\") then .x * 320 else 0 end),\\(.y * 240)\") | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "responses": [
            {
              "localizedObjectAnnotations": [
                {
                  "mid": "/m/0jbk",
                  "name": "Animal",
                  "score": 0.776703,
                  "boundingPoly": {
                    "normalizedVertices": [
                      {
                        "y": 0.327939
                      },
                      {
                        "x": 0.27193785,
                        "y": 0.327939
                      },
                      {
                        "x": 0.27193785,
                        "y": 0.62985307
                      },
                      {
                        "y": 0.62985307
                      }
                    ]
                  }
                }
              ]
            }
          ]
        },
        "output": "0,78.70536 87.020112,78.70536 87.020112,151.1647368 0,151.1647368"
      }
    ],
    "identifier": 61166764
  },
  {
    "context": [
      "I am trying to sort them in ascending order based on the number_of_requests.",
      "Basically, the sort_by function treats \"558\"/\"59944\" as lesser than \"8\" , \"6\" etc. Is there a way to work around this?",
      "You need to convert the value to a number, with `tonumber`:",
      "jq -s -c 'sort_by(.number_of_requests|tonumber)'"
    ],
    "utterance": "Sort objects by the numerical value of the 'number_of_requests' field in ascending order, even though the field is stored as a string.",
    "expressions": [
      "sort_by(.number_of_requests|tonumber)"
    ],
    "data": [
      {
        "input": [
          {
            "AccountID": "290859614811",
            "number_of_requests": "59944"
          },
          {
            "AccountID": "421258792169",
            "number_of_requests": "3132"
          },
          {
            "AccountID": "433594311540",
            "number_of_requests": "1541"
          },
          {
            "AccountID": "406912498377",
            "number_of_requests": "678"
          },
          {
            "AccountID": "850981987534",
            "number_of_requests": "558"
          },
          {
            "AccountID": "763725063017",
            "number_of_requests": "470"
          },
          {
            "AccountID": "notaccount",
            "number_of_requests": "8"
          }
        ],
        "output": [
          {
            "AccountID": "notaccount",
            "number_of_requests": "8"
          },
          {
            "AccountID": "763725063017",
            "number_of_requests": "470"
          },
          {
            "AccountID": "850981987534",
            "number_of_requests": "558"
          },
          {
            "AccountID": "406912498377",
            "number_of_requests": "678"
          },
          {
            "AccountID": "433594311540",
            "number_of_requests": "1541"
          },
          {
            "AccountID": "421258792169",
            "number_of_requests": "3132"
          },
          {
            "AccountID": "290859614811",
            "number_of_requests": "59944"
          }
        ]
      }
    ],
    "identifier": 61199207
  },
  {
    "context": [
      "I have a complex JSON file that contains hundreds of \"attributes\" with their types identified by \"objectTypeAttributeId\".",
      "I need to create output JSON using particular values picked out (according to the \"objectTypeAttributeId\" value) of input JSON in format like this:",
      "{\n    \"tickets\": [\n        {\n            \"ticketid\": \"ITSM-24210\",\n            \"hostnames\": [\"testhost1\", \"testhost2\"],\n            \"date\": \"28.02.2020 11:45\"\n        }\n    ]\n}",
      "Your original solution almost works, you did a good job there, just needed a map:",
      ".objectEntries[].attributes | \n{ticketid: . | map(select(.objectTypeAttributeId == 328))[0] | \n.objectAttributeValues[0].displayValue, \ndate: . | map(select(.objectTypeAttributeId == 330))[0] |\n.objectAttributeValues[0].displayValue, \nhostnames: . | map(select(.objectTypeAttributeId == 329))[0] | \n[.objectAttributeValues[].displayValue]}",
      "Assuming a ticket is to be generated for each object entry:\n{tickets: [\n  .objectEntries[]\n  | [.attributes[]\n    | [.objectTypeAttributeId,\n      (.objectAttributeValues | map(.displayValue))] as [$id, $val]\n    |   if $id == 328 then {ticketId:  $val[0]}\n      elif $id == 329 then {hostnames: $val}\n      elif $id == 330 then {date:      $val[0]}\n      else empty end\n  ] | add\n]}"
    ],
    "utterance": "Extract ticketid where objectTypeAttributeId=328, an array of hostnames where objectTypeAttributeId=329, and date where objectTypeAttributeId=330 from each object entry, assembling them into a single object for each entry under a tickets array.",
    "expressions": [
      ".objectEntries[].attributes | {ticketid: . | map(select(.objectTypeAttributeId == 328))[0] | .objectAttributeValues[0].displayValue, date: . | map(select(.objectTypeAttributeId == 330))[0] | .objectAttributeValues[0].displayValue, hostnames: . | map(select(.objectTypeAttributeId == 329))[0] | [.objectAttributeValues[].displayValue]}",
      "{tickets: [ .objectEntries[] | [.attributes[] | [.objectTypeAttributeId, (.objectAttributeValues | map(.displayValue))] as [$id, $val] | if $id == 328 then {ticketid: $val[0]} elif $id == 329 then {hostnames: $val} elif $id == 330 then {date: $val[0]} else empty end ] | add ]}"
    ],
    "data": [
      {
        "input": {
          "objectEntries": [
            {
              "attributes": [
                {
                  "id": 279792,
                  "objectTypeAttributeId": 328,
                  "objectAttributeValues": [
                    {
                      "displayValue": "ITSM-24210"
                    }
                  ]
                },
                {
                  "id": 279795,
                  "objectTypeAttributeId": 329,
                  "objectAttributeValues": [
                    {
                      "displayValue": "testhost1"
                    },
                    {
                      "displayValue": "testhost2"
                    }
                  ]
                },
                {
                  "id": 279793,
                  "objectTypeAttributeId": 330,
                  "objectAttributeValues": [
                    {
                      "displayValue": "28.02.2020 11:45"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "tickets": [
            {
              "ticketid": "ITSM-24210",
              "hostnames": [
                "testhost1",
                "testhost2"
              ],
              "date": "28.02.2020 11:45"
            }
          ]
        }
      }
    ],
    "identifier": 61394066
  },
  {
    "context": [
      "I have a JSON as follows but need a way to remove nulls before putting it into elasticsearch. Looking for a simple jq command to remove nulls that i can incorporate into my bash script unless there&#39;s a way to do this in elasticsearch",
      "del(.[][] | nulls)",
      "Please use https://github.com/stedolan/jq/issues/104#issuecomment-289637207 which work with the latest version."
    ],
    "utterance": "Remove all fields with null values from the data structure before further processing.",
    "expressions": [
      "del(.. | select(type == \"object\") | .[]? | select(. == null))",
      "with_entries(select(.value != null))"
    ],
    "data": [
      {
        "input": {
          "master_no": {
            "master_no": 100000000,
            "barcode": "E00000000",
            "external_key": null,
            "umid": null
          },
          "cust_id": {
            "other_cust_id": null,
            "cust_reference": null,
            "external_key": null,
            "list_id": null,
            "cust_id": null
          },
          "customer_name": null,
          "master_desc": "test Custom Patch - test",
          "barcode": "E00000000",
          "container_master_no": null,
          "master_status": "I",
          "length": "0:00",
          "format_no": {
            "format_desc": null,
            "external_key": null,
            "format_no": null
          },
          "lib_master_audio": [
            {
              "master_no": 10000000,
              "audio_channel_no": {
                "audio_channel_no": 10,
                "audio_channel": "1",
                "external_key": null
              }
            },
            {
              "master_no": 100000000,
              "audio_channel_no": {
                "audio_channel_no": 10,
                "audio_channel": "2",
                "external_key": null
              }
            }
          ]
        }
      }
    ],
    "identifier": 61516010
  },
  {
    "context": [
      "Note that the first key `\"129\"` should be addressed by position, similar to `keys[0]` as shown above, as the number is not known beforehand. The value of key `id` is also set to `\"130\"`. Both should be set with the bash variable `$nextID` imported into jq.",
      "new_group=`echo $group | jq --arg nextID $nextID --arg title $title '(keys_unsorted|first) as $i | with_entries(if .key == $i then .key=$nextID | .value.id=$nextID | .value.title=$title else . end)'`",
      "with_entries(.key=$nextID | .value.id=$nextID)",
      "new_group=`echo $group | jq --arg nextID \"$nextID\" --arg title \"$title\" 'with_entries(.key=$nextID | .value.id=$nextID | .value.title=$title)'`",
      "Output:",
      "{ \"130\": { \"bounds\": { \"left\": 20, \"top\": 20, \"width\": 250, \"height\": 200 }, \"slot\": 88, \"userSize\": null, \"stackTabs\": true, \"showThumbs\": true, \"showUrls\": true, \"tileIcons\": true, \"catchOnce\": true, \"catchRules\": \"\", \"title\": \"new title\", \"id\": \"130\" } }"
    ],
    "utterance": "Rename the only top-level object key to a new value and set both the inner object's 'id' and 'title' fields to the same new value and a provided title string.",
    "expressions": [
      "with_entries(.key=$nextID | .value.id=$nextID | .value.title=$title)",
      "(keys_unsorted|first) as $i | with_entries(if .key == $i then .key=$nextID | .value.id=$nextID | .value.title=$title else . end)"
    ],
    "data": [
      {
        "input": {
          "129": {
            "bounds": {
              "left": 20,
              "top": 20,
              "width": 250,
              "height": 200
            },
            "slot": 88,
            "userSize": null,
            "stackTabs": true,
            "showThumbs": true,
            "showUrls": true,
            "tileIcons": true,
            "catchOnce": true,
            "catchRules": "",
            "title": "",
            "id": 129
          }
        },
        "output": {
          "130": {
            "bounds": {
              "left": 20,
              "top": 20,
              "width": 250,
              "height": 200
            },
            "slot": 88,
            "userSize": null,
            "stackTabs": true,
            "showThumbs": true,
            "showUrls": true,
            "tileIcons": true,
            "catchOnce": true,
            "catchRules": "",
            "title": "new title",
            "id": "130"
          }
        }
      }
    ],
    "identifier": 61158966
  },
  {
    "context": [
      "host001 host002 host003 host004",
      "echo $server_list | jq -R 'split (\" \")'  | jq '.[]' | jq -s '{hosts:map({\"hostid\":.})}'",
      "jq -R 'split(\" \") | {hosts:map({\"hostid\":.})}' <<< \"$server_list\""
    ],
    "utterance": "Transform a space-separated list of server hostnames into an object with a hosts array where each element has a hostid field equal to a hostname.",
    "expressions": [
      "jq -R 'split(\" \") | {hosts:map({\"hostid\":.})}' <<< \"$server_list\"",
      "echo $server_list | jq -R 'split (\" \")' | jq '.[]' | jq -s '{hosts:map({\"hostid\":.})}'"
    ],
    "data": [
      {
        "input": "host001 host002 host003 host004",
        "output": {
          "hosts": [
            {
              "hostid": "host001"
            },
            {
              "hostid": "host002"
            },
            {
              "hostid": "host003"
            },
            {
              "hostid": "host004"
            }
          ]
        }
      }
    ],
    "identifier": 61515781
  },
  {
    "context": [
      "Is it possible to return the key as well? So like below:\r\n\r\n    \"top\": \"0\"\r\n    \"two\": \"2\"",
      "For a valid JSON output:\r\n```\r\n{top} + (.sub | {two})\r\n```"
    ],
    "utterance": "Return an object containing the values of the 'top' key and the 'two' key within 'sub' with their corresponding keys.",
    "expressions": [
      "{top} + (.sub | {two})"
    ],
    "data": [
      {
        "input": {
          "top": "0",
          "sub": {
            "one": "1",
            "two": "2",
            "three": "3"
          }
        },
        "output": {
          "top": "0",
          "two": "2"
        }
      }
    ],
    "identifier": 61352655
  },
  {
    "context": [
      "# file1.json\n```\n[\n  {\n    \"a\": \"a\",\n    \"b\": \"b\"\n  },\n  {\n    \"a\": \"a\",\n    \"b\": \"b\"\n  }\n]\n```",
      "# file2.json\n```\n[\n  {\n    \"c\": \"c\"\n  },\n  {\n    \"c\": \"c\"\n  }\n]\n```",
      "# desired output: file3.json\n```\n[\n  {\n    \"a\": \"a\",\n    \"b\": \"b\",\n    \"c\": \"c\"\n  },\n  {\n    \"a\": \"a\",\n    \"b\": \"b\",\n    \"c\": \"c\"\n  }\n]\n```",
      "jq -s 'transpose | map(add)' file1.json file2.json",
      "For this type of problem, `transpose` (think `zip`) can often be used to produce compact solutions.  In the present case:\n\n    jq -s 'transpose | map(add)' file1.json file2.json"
    ],
    "utterance": "Combine corresponding objects from two arrays in separate files so that the output array contains merged objects with fields from both sources.",
    "expressions": [
      "jq -s 'transpose | map(add)' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": "a",
              "b": "b"
            },
            {
              "a": "a",
              "b": "b"
            }
          ],
          [
            {
              "c": "c"
            },
            {
              "c": "c"
            }
          ]
        ],
        "output": [
          {
            "a": "a",
            "b": "b",
            "c": "c"
          },
          {
            "a": "a",
            "b": "b",
            "c": "c"
          }
        ]
      }
    ],
    "identifier": 61513671
  },
  {
    "context": [
      "Now I want to try and extract the `title` from `video-card_n ellip` and the `href` from `video-card_lk` from the resulting json file with the [jq](https://github.com/stedolan/jq) tool but I know how to use `jq` enough.",
      "I'd like `jq` (or `pup`) to output a flat file : the url as the first column and the title as the second column.",
      "[ [ .. | arrays[] | select(.class == \"video-card_n ellip\").title],\n  [ .. | arrays[] | select(.class == \"video-card_lk\").href]]\n| transpose"
    ],
    "utterance": "Extract pairs of video titles and relative URLs from elements with classes 'video-card_n ellip' and 'video-card_lk', returning each as a two-column output with URL first and title second.",
    "expressions": [
      "[ [ .. | arrays[] | select(.class == \"video-card_n ellip\").title],\n  [ .. | arrays[] | select(.class == \"video-card_lk\").href]]\n| transpose"
    ],
    "identifier": 61261777
  },
  {
    "context": [
      "The average and min results are not correct and I can't for the life of me figure out what I am doing wrong.",
      "function JSONProccessor {\n     jq '\n      def myMathFunc:\n        if (.name | test(\"^sum\", \"\")) then\n          {\"\\(.name)\": (.values | add)}                           \n        elif (.name | test(\"^avg|^global-avg\", \"\")) then\n          {\"\\(.name)\": ((.values | add) / (.values | length)) }   \n        elif (.name | test(\"^max\", \"\")) then\n          {\"\\(.name)\": (.values | max) }   \n        elif (.name | test(\"^min\", \"\")) then\n          {\"\\(.name)\": (.values | min) } \n        else\n          {\"\\(.name)\": .values[]}                              \n        end;",
      "[\n      .Response.stats.data[] |\n      .identifier.names[] as $name |\n      .identifier.values[] as $val |\n      {\"\\($name)\": \"\\($val)\"} + ([\n        .metric[] | myMathFunc\n      ] | add)\n    ]",
      "Input JSON",
      "{\n  \"Response\" : {\n    \"TimeUnit\" : [ 1588153140000, 1588153200000 ],\n    \"metaData\" : {\n      \"errors\" : [ ]\n    },\n    \"resultTruncated\" : false,\n    \"stats\" : {\n      \"data\" : [ {\n        \"identifier\" : {\n          \"names\" : [ \"apiproxy\" ],\n          \"values\" : [ \"authn\" ]\n        },\n        \"metric\" : [ {\n          \"env\" : \"prod\",\n          \"name\" : \"min(request_processing_latency)\",\n          \"values\" : [ 917.0, 6.0 ]\n        }, {\n          \"env\" : \"prod\",\n          \"name\" : \"avg(total_response_time)\",\n          \"values\" : [ 2203.5, 13.0 ]\n        }, {\n          \"env\" : \"prod\",\n          \"name\" : \"max(request_processing_latency)\",\n          \"values\" : [ 1286.0, 6.0 ]\n        }, {\n          \"env\" : \"prod\",\n          \"name\" : \"global-avg-total_response_time\",\n          \"values\" : [ 1473.3333333333333 ]\n        }, {\n          \"env\" : \"prod\",\n          \"name\" : \"sum(message_count)\",\n          \"values\" : [ 2.0, 1.0 ]\n        } \n        ]\n      }\n     ]\n    }\n  }\n}",
      "Output ",
      "[\n  {\n    \"apiproxy\": \"authn\",\n    \"min(request_processing_latency)\": 923,\n    \"avg(total_response_time)\": 2216.5,\n    \"max(request_processing_latency)\": 1292,\n    \"global-avg-total_response_time\": 1473.3333333333333,\n    \"sum(message_count)\": 3\n  }\n]",
      "The test() function does not even take arguments separated by ',' but only by ';' de-limiter. ",
      "Removing the 2nd argument should make your function work as expected."
    ],
    "utterance": "Aggregate metrics such as sum, average, minimum, and maximum from arrays under .Response.stats.data[].metric[] based on the metric name, and output a single object containing these aggregated values with the associated identifier.",
    "expressions": [
      "def myMathFunc:\n  if (.name | test(\"^sum\")) then\n    {\"\\(.name)\": (.values | add)}\n  elif (.name | test(\"^avg|^global-avg\")) then\n    {\"\\(.name)\": ((.values | add) / (.values | length))}\n  elif (.name | test(\"^max\")) then\n    {\"\\(.name)\": (.values | max)}\n  elif (.name | test(\"^min\")) then\n    {\"\\(.name)\": (.values | min)}\n  else\n    {\"\\(.name)\": .values[]}\n  end;\n\n[\n  .Response.stats.data[] |\n  .identifier.names[] as $name |\n  .identifier.values[] as $val |\n  {\"\\($name)\": \"\\($val)\"} + ([\n    .metric[] | myMathFunc\n  ] | add)\n]"
    ],
    "data": [
      {
        "input": {
          "Response": {
            "TimeUnit": [
              1588153140000,
              1588153200000
            ],
            "metaData": {
              "errors": []
            },
            "resultTruncated": false,
            "stats": {
              "data": [
                {
                  "identifier": {
                    "names": [
                      "apiproxy"
                    ],
                    "values": [
                      "authn"
                    ]
                  },
                  "metric": [
                    {
                      "env": "prod",
                      "name": "min(request_processing_latency)",
                      "values": [
                        917.0,
                        6.0
                      ]
                    },
                    {
                      "env": "prod",
                      "name": "avg(total_response_time)",
                      "values": [
                        2203.5,
                        13.0
                      ]
                    },
                    {
                      "env": "prod",
                      "name": "max(request_processing_latency)",
                      "values": [
                        1286.0,
                        6.0
                      ]
                    },
                    {
                      "env": "prod",
                      "name": "global-avg-total_response_time",
                      "values": [
                        1473.3333333333333
                      ]
                    },
                    {
                      "env": "prod",
                      "name": "sum(message_count)",
                      "values": [
                        2.0,
                        1.0
                      ]
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": [
          {
            "apiproxy": "authn",
            "min(request_processing_latency)": 923,
            "avg(total_response_time)": 2216.5,
            "max(request_processing_latency)": 1292,
            "global-avg-total_response_time": 1473.3333333333333,
            "sum(message_count)": 3
          }
        ]
      }
    ],
    "identifier": 61502871
  },
  {
    "context": [
      "I want to get hr for every value from blockHistory where time from hashrateHistory is the biggest time <= blockHistory value.",
      "result i want:\n[\n  {\n    \"lastHr\": 2,\n    \"time\": 10\n  },\n  {\n    \"lastHr\": 4,\n    \"time\": 12\n  },\n  {\n    \"lastHr\": 6,\n    \"time\": 14\n  },\n  {\n    \"lastHr\": 7,\n    \"time\": 17\n  }\n]",
      "(.hashrateHistory | sort_by(.time)) as $hashrate\n| .blockHistory | map(\n\t. as $max_time\n\t| $hashrate\n\t| map(select(.time <= $max_time))[-1]\n\t| {lastHr: .hr, time: $max_time}\n)",
      ".hashrateHistory as $hashrateHistory\n| INDEX($hashrateHistory[]; .time) as $dict\n| ($hashrateHistory | sort_by(.time) ) as $sorted\n| ($sorted | map(.time)) as $sorted_time\n| ($sorted | map(.hr)) as $sorted_hr\n| .blockHistory\n| map( . as $t\n       | $dict[$t|tostring]\n       | if . then {lastHr: .hr, time }\n         else (-2 - ($sorted_time | bsearch($t))) as $i\n         | {lastHr: $sorted_hr[$i], time: $t}\n         end )"
    ],
    "utterance": "For each value in blockHistory, find the hr from hashrateHistory where time is the largest value less than or equal to the blockHistory value.",
    "expressions": [
      "(.hashrateHistory | sort_by(.time)) as $hashrate | .blockHistory | map(. as $max_time | $hashrate | map(select(.time <= $max_time))[-1] | {lastHr: .hr, time: $max_time})",
      ".hashrateHistory as $hashrateHistory | INDEX($hashrateHistory[]; .time) as $dict | ($hashrateHistory | sort_by(.time) ) as $sorted | ($sorted | map(.time)) as $sorted_time | ($sorted | map(.hr)) as $sorted_hr | .blockHistory | map( . as $t | $dict[$t|tostring] | if . then {lastHr: .hr, time } else (-2 - ($sorted_time | bsearch($t))) as $i | {lastHr: $sorted_hr[$i], time: $t} end )"
    ],
    "data": [
      {
        "input": {
          "blockHistory": [
            10,
            12,
            14,
            17
          ],
          "hashrateHistory": [
            {
              "hr": 1,
              "time": 9
            },
            {
              "hr": 2,
              "time": 10
            },
            {
              "hr": 3,
              "time": 11
            },
            {
              "hr": 4,
              "time": 12
            },
            {
              "hr": 5,
              "time": 13
            },
            {
              "hr": 6,
              "time": 14
            },
            {
              "hr": 7,
              "time": 15
            }
          ]
        },
        "output": [
          {
            "lastHr": 2,
            "time": 10
          },
          {
            "lastHr": 4,
            "time": 12
          },
          {
            "lastHr": 6,
            "time": 14
          },
          {
            "lastHr": 7,
            "time": 17
          }
        ]
      }
    ],
    "identifier": 61043906
  },
  {
    "context": [
      "Using JQ I would like to take a complex JSON object that includes JSON embedded as strings and then turn it all into a valid string I can easily embed in other JSON objects.",
      "I need to turn this all into the following string:\n\n\"{\\\"region\\\": \\\"CA\\\",\\\"waf_rule_tags\\\": \\\"{\\\\\\\"RULEID:942100\\\\\\\":[\\\\\\\"application-multi\\\\\\\",\\\\\\\"language-multi\\\\\\\",\\\\\\\"platform-multi\\\\\\\",\\\\\\\"attack-sqli\\\\\\\",\\\\\\\"OWASP_CRS/WEB_ATTACK/SQL_INJECTION\\\\\\\",\\\\\\\"WASCTC/WASC-19\\\\\\\",\\\\\\\"OWASP_TOP_10/A1\\\\\\\",\\\\\\\"OWASP_AppSensor/CIE1\\\\\\\",\\\\\\\"PCI/6.5.2\\\\\\\"]}\\\"}\"",
      "Assuming that your original JSON object is in a file named object.json, and that the template is in template.json, you could write:\n\njq --argfile object object.json '.text = ($object | tostring)' template.json",
      "JQ provides `tojson` and `fromjson` filters for that.",
      "The JQ manual says about `tojson`:\n\n>The `tojson` builtin differs from `tostring` in that  `tostring`  returns  strings  unmodified,  while  `tojson`  encodes strings as JSON strings."
    ],
    "utterance": "Convert an entire object, including fields with embedded JSON strings, into a single escaped string suitable for use as a string field in another object.",
    "expressions": [
      ". | tojson",
      "jq --argfile object object.json '.text = ($object | tojson)' template.json"
    ],
    "data": [
      {
        "input": {
          "region": "CA",
          "waf_rule_tags": "{\"RULEID:942100\":[\"application-multi\",\"language-multi\",\"platform-multi\",\"attack-sqli\",\"OWASP_CRS/WEB_ATTACK/SQL_INJECTION\",\"WASCTC/WASC-19\",\"OWASP_TOP_10/A1\",\"OWASP_AppSensor/CIE1\",\"PCI/6.5.2\"]}"
        },
        "output": "{\"region\":\"CA\",\"waf_rule_tags\":\"{\\\"RULEID:942100\\\":[\\\"application-multi\\\",\\\"language-multi\\\",\\\"platform-multi\\\",\\\"attack-sqli\\\",\\\"OWASP_CRS/WEB_ATTACK/SQL_INJECTION\\\",\\\"WASCTC/WASC-19\\\",\\\"OWASP_TOP_10/A1\\\",\\\"OWASP_AppSensor/CIE1\\\",\\\"PCI/6.5.2\\\"]}\"}"
      }
    ],
    "identifier": 61492210
  },
  {
    "context": [
      "Using jq I want create new objects from items array, merge it with objectNumbers and sort it using number.",
      "In this moment, I have new objects from items:\r\n\r\n```\r\njq '.items[] | {type: \"itemNumber\", number: .}'\r\n```",
      "but I don't know how can I merge it with objectNumbers.",
      "Finally, I want follwing structure:\r\n\r\n...\r\n     {\r\n        \"type\": \"itemNumber\",\r\n        \"number\": 4\r\n     },\r\n     {\r\n        \"type\": \"itemNumber\",\r\n        \"number\": 5\r\n     },\r\n     {\r\n        \"type\": \"objectNumber\",\r\n        \"number\": 6\r\n     },\r\n     {\r\n        \"type\": \"objectNumber\",\r\n        \"number\": 7\r\n     },\r\n...",
      "Just put your script's products into an array, add it to `objectNumbers` and sort by `number` field. E.g.:",
      "[.items[] | {type: \"itemNumber\", number: .}] + .objectNumbers\n| sort_by(.number)"
    ],
    "utterance": "Create objects from the 'items' array with type 'itemNumber', merge these with 'objectNumbers', and sort the result by the 'number' field.",
    "expressions": [
      "[.items[] | {type: \"itemNumber\", number: .}] + .objectNumbers | sort_by(.number)"
    ],
    "data": [
      {
        "input": {
          "items": [
            4,
            5,
            1,
            3,
            2
          ],
          "objectNumbers": [
            {
              "type": "objectNumber",
              "number": 8
            },
            {
              "type": "objectNumber",
              "number": 7
            },
            {
              "type": "objectNumber",
              "number": 10
            },
            {
              "type": "objectNumber",
              "number": 6
            },
            {
              "type": "objectNumber",
              "number": 9
            }
          ]
        },
        "output": [
          {
            "type": "itemNumber",
            "number": 1
          },
          {
            "type": "itemNumber",
            "number": 2
          },
          {
            "type": "itemNumber",
            "number": 3
          },
          {
            "type": "itemNumber",
            "number": 4
          },
          {
            "type": "itemNumber",
            "number": 5
          },
          {
            "type": "objectNumber",
            "number": 6
          },
          {
            "type": "objectNumber",
            "number": 7
          },
          {
            "type": "objectNumber",
            "number": 8
          },
          {
            "type": "objectNumber",
            "number": 9
          },
          {
            "type": "objectNumber",
            "number": 10
          }
        ]
      }
    ],
    "identifier": 61041368
  },
  {
    "context": [
      "Each entry could be any \"type\".  I want to filter by just \"COVID19\" AND print the \"id\":",
      "COVID19 asdf1",
      "COVID19 abcde1",
      "JQ can easily filter entries that are \"COVID19\" for me:",
      "cat dat.json |jq -r '.[].data |select(.type == \"COVID19\")'",
      "But once I've drilled down in to `.[].data` I can no longer reference `.[].id`.",
      "How do I reference a higher-tier key / value after filtering results?  Is there a shortcut for the root object that is something like an absolute path?",
      "One technique is to store the item of interest in a jq variable, e.g. along the lines of:",
      ".[]\n| .id as $id\n| .data\n| select(.type == \"COVID19\")\n| [.type, $id]\n| join(\" \")",
      "A simpler solution can be just to modify access from `.type` to `.data.type` so there's no need to store variables.",
      ".[]\n| select(.data.type == \"COVID19\")\n| [.data.type, .id] | join(\" \")"
    ],
    "utterance": "Filter the list to entries where type is COVID19 and print each one's type and id, separated by a space.",
    "expressions": [
      ".[] | .id as $id | .data | select(.type == \"COVID19\") | [.type, $id] | join(\" \")",
      ".[] | select(.data.type == \"COVID19\") | [.data.type, .id] | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "abcde1",
            "data": {
              "type": "COVID19",
              "date": "2020-04-15"
            }
          },
          {
            "id": "hijkl1",
            "data": {
              "type": "COVID20",
              "date": "2020-04-02"
            }
          },
          {
            "id": "asdf1",
            "data": {
              "type": "COVID19",
              "date": "2020-04-16"
            }
          },
          {
            "id": "jkl1",
            "data": {
              "type": "COVID20",
              "date": "2020-04-16"
            }
          }
        ],
        "output": [
          "COVID19 abcde1",
          "COVID19 asdf1"
        ]
      }
    ],
    "identifier": 61260384
  },
  {
    "context": [
      "I have an environment variable that contains the path `.foo.bar`. I'm trying to access the data at `.foo.bar` with that environment variable.",
      "Now if I want to access this with the environment variable instead, I'd do something like this:",
      "$ JSON_INDEX=\".foo.bar\"",
      "$ cat /tmp/data.json | jq --arg KEY $JSON_INDEX '.[$KEY]'",
      "However, this outputs null, because as far as I understand, you can't use paths in `[]`? I'm trying to avoid from having to reformat the `JSON_INDEX` variable if possible. Is there any way I can do this in native `jq` without altering the variable?"
    ],
    "utterance": "Access the value at a path stored as a string such as '.foo.bar' in an environment variable, without reformatting the variable.",
    "expressions": [
      "jq --arg KEY '.foo.bar' 'getpath([$KEY[1:3], $KEY[5:]])'",
      "jq --arg KEY '.foo.bar' 'paths as $p | select($p|join(\".\") == $KEY[1:]) | getpath($p)'"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": 10
          }
        },
        "output": 10
      }
    ],
    "identifier": 61331068
  },
  {
    "context": [
      "now `if (count == 3)` I want to concatenate the name with the version.",
      "But now i also want one more conditon  `if (count ==3 and version != RealVersion)` then only i want the `version` I tried a lot of command none of them are working.",
      "So EXPECTED OUTPUT =\r\n    `[ford:111,BMW:155]`\r\nSo, `ford:133` would not come in the output",
      ".name + \": \" + (\r\n    .RealVersion as $r\r\n  | .availableVersions[]\r\n  | select(.count == 3 and .version != $r).version \r\n  | tostring\r\n)",
      "jq --compact --slurp '\r\n\t.[] |= . as $r\r\n\t\t| .availableVersions[]\r\n\t\t| select(.count == 3 and .version != $r.RealVersion)\r\n\t\t| \"\\($r.name):\\(.version)\"\r\n'"
    ],
    "utterance": "Select objects where count is 3 and version is not equal to RealVersion, then concatenate name and version with a colon.",
    "expressions": [
      ".name + \": \" + (.RealVersion as $r | .availableVersions[] | select(.count == 3 and .version != $r).version | tostring)",
      ".availableVersions[] as $v | select($v.count == 3 and $v.version != .RealVersion) | \"\u0000(.name):\u0000($v.version)\"",
      "[.[] | . as $r | .availableVersions[] | select(.count == 3 and .version != $r.RealVersion) | \"\\($r.name):\\(.version)\"]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 2
              },
              {
                "version": 133,
                "count": 3
              }
            ],
            "RealVersion": 133
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 144,
                "count": 1
              },
              {
                "version": 155,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": [
          "ford:111",
          "bmw:155"
        ]
      }
    ],
    "identifier": 61033890
  },
  {
    "context": [
      "I\u2019d like to use `jq` to find all objects with key \"5\" provided that the previous item in the list has key \"4\". Only the middle entry should match.",
      "If the goal is to find all objects with key `5` provided that the **immediately** preceding item has key `4`, then the following is an efficient solution:",
      "foreach .[] as $d ({};\n    if .previous == 4 and $d.key == 5\n    then .emit = $d \n    else .emit = null \n    end | .previous = $d.key;\n    .emit | select(.))",
      "Here is an example which also illustrates that the solution using `reduce` elsewhere on this page produces inaccurate results relative to the above interpretation.",
      "Result:\n\n```\n{\"key\":5,\"value\":{\"b\":\"c\"}}\n{\"key\":5,\"value\":{\"e\":\"f\"}}\n```"
    ],
    "utterance": "Select all objects where key equals 5 and the immediately preceding item has key equal to 4.",
    "expressions": [
      "foreach .[] as $d ({};\n    if .previous == 4 and $d.key == 5\n    then .emit = $d \n    else .emit = null \n    end | .previous = $d.key;\n    .emit | select(.))"
    ],
    "data": [
      {
        "input": [
          {
            "key": 4,
            "value": {
              "a": "b"
            }
          },
          {
            "key": 5,
            "value": {
              "b": "c"
            }
          },
          {
            "key": 5,
            "value": {
              "c": "d"
            }
          },
          {
            "key": 4,
            "value": {
              "d": "e"
            }
          },
          {
            "key": 5,
            "value": {
              "e": "f"
            }
          }
        ],
        "output": [
          {
            "key": 5,
            "value": {
              "b": "c"
            }
          },
          {
            "key": 5,
            "value": {
              "e": "f"
            }
          }
        ]
      }
    ],
    "identifier": 61488826
  },
  {
    "context": [
      "I am trying to convert a bunch of child properties from stringified JSON to JSON.",
      "$ jq '.a[].c |= fromjson' FileZ",
      "However when one of the \"c\" properties above is missing it fails.",
      "How can I ignore this error and instead yield:",
      "Check whether `.c` exists before feeding it to `fromjson`.",
      ".a[] |= if has(\"c\") then .c |= fromjson else . end",
      "You might wish to consider using `walk`:",
      "walk(if type == \"object\" and has(\"c\") then .c |= fromjson else . end)",
      "The following is a generalized solution without any explicit use of `if`, but it does require [tag:jq] version 1.5 or later:",
      "(.. | .c? // empty) |= fromjson"
    ],
    "utterance": "Convert all existing properties named \"c\" from a stringified JSON object to an object, ignoring entries where \"c\" is missing.",
    "expressions": [
      ".a[] |= if has(\"c\") then .c |= fromjson else . end",
      "walk(if type == \"object\" and has(\"c\") then .c |= fromjson else . end)",
      "(.. | .c? // empty) |= fromjson"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "b": "x",
              "c": "{\"foo\": 1}"
            },
            {
              "b": "y",
              "c": "{\"foo\": 2}"
            }
          ]
        },
        "output": {
          "a": [
            {
              "b": "x",
              "c": {
                "foo": 1
              }
            },
            {
              "b": "y",
              "c": {
                "foo": 2
              }
            }
          ]
        }
      },
      {
        "input": {
          "a": [
            {
              "b": "x",
              "c": "{\"foo\": 1}"
            },
            {
              "b": "y"
            }
          ]
        },
        "output": {
          "a": [
            {
              "b": "x",
              "c": {
                "foo": 1
              }
            },
            {
              "b": "y"
            }
          ]
        }
      }
    ],
    "identifier": 61257879
  },
  {
    "context": [
      "I have this demo.json file now `if (count == 3)`. I want to delete the key value pair of count and the respective version.",
      "So my output should be like.",
      "Just remap `availableVersions` selecting objects whose `count` is not 3.",
      "```\n.availableVersions |= map(select(.count != 3))\n```"
    ],
    "utterance": "Remove all objects in the availableVersions array where count is 3.",
    "expressions": [
      ".availableVersions |= map(select(.count != 3))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 111,
                "count": 3
              },
              {
                "version": 122,
                "count": 2
              },
              {
                "version": 133,
                "count": 3
              }
            ],
            "RealVersion": 133
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 144,
                "count": 1
              },
              {
                "version": 155,
                "count": 3
              }
            ],
            "RealVersion": 120
          }
        ],
        "output": [
          {
            "name": "ford",
            "availableVersions": [
              {
                "version": 122,
                "count": 2
              }
            ],
            "RealVersion": 133
          },
          {
            "name": "bmw",
            "availableVersions": [
              {
                "version": 144,
                "count": 1
              }
            ],
            "RealVersion": 120
          }
        ]
      }
    ],
    "identifier": 61485551
  },
  {
    "context": [
      "I am looking for something like:\n```\njq '.planklist' \none,two,three,four\n```"
    ],
    "utterance": "Extract the entire planklist array from the object.",
    "expressions": [
      ".planklist"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "plankVal": 2,
          "planklist": [
            "one",
            "two",
            "three",
            "four"
          ]
        },
        "output": [
          "one",
          "two",
          "three",
          "four"
        ]
      }
    ],
    "identifier": 61464650
  },
  {
    "context": [
      "I need to find out how to access the ParameterKeys 'b' and 'd' in an optimal way (WITHOUT using array indexes) using e.g. jq so that the resulting array would be:",
      "map(if .ParameterKey == \"b\" then .ParameterValue = \"5\"\n    elif .ParameterKey == \"d\" then .ParameterValue = \"6\"\n    else . end)"
    ],
    "utterance": "Update ParameterValue to \"5\" when ParameterKey is \"b\" and to \"6\" when ParameterKey is \"d\", leaving all other objects unchanged.",
    "expressions": [
      "map(if .ParameterKey == \"b\" then .ParameterValue = \"5\" elif .ParameterKey == \"d\" then .ParameterValue = \"6\" else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "a",
            "ParameterValue": "1"
          },
          {
            "ParameterKey": "b",
            "ParameterValue": "2"
          },
          {
            "ParameterKey": "c",
            "ParameterValue": "3"
          },
          {
            "ParameterKey": "d",
            "ParameterValue": "4"
          }
        ],
        "output": [
          {
            "ParameterKey": "a",
            "ParameterValue": "1"
          },
          {
            "ParameterKey": "b",
            "ParameterValue": "5"
          },
          {
            "ParameterKey": "c",
            "ParameterValue": "3"
          },
          {
            "ParameterKey": "d",
            "ParameterValue": "6"
          }
        ]
      }
    ],
    "identifier": 61252035
  },
  {
    "context": [
      "I want to count the occurrences of \"bar\" in array label then exclude object if count > 1 (can be in 2part)",
      "ex after process:\n\n[\n  {\n    \"title\": \"foo_42\",\n    \"label\": [\n      \"bar-one\"\n    ]\n  }\n]",
      "map(select(.label | map(select(contains(\"bar\"))) | length <= 1))",
      "jq ' \n   map(\n     select(.label |\n       any(., map(select(index(\"bar\"))); length < 2)\n     )\n)' json",
      "reduce inputs[] as $d (. ;\n    if [ $d.label[] | select(contains(\"bar\")) ] | length == 1 then\n        . + [$d]\n    else\n        empty\n    end\n )"
    ],
    "utterance": "Select objects where the 'label' array contains at most one element that includes the substring \"bar\".",
    "expressions": [
      "map(select(.label | map(select(contains(\"bar\"))) | length <= 1))",
      "jq 'map(select(.label | map(select(contains(\"bar\"))) | length <= 1))'",
      "jq 'map(select(.label | [ .[] | select(contains(\"bar\")) ] | length < 2))'",
      "reduce inputs[] as $d (. ; if [ $d.label[] | select(contains(\"bar\")) ] | length == 1 then . + [$d] else empty end )",
      "jq 'map(select([.label[] | select(contains(\"bar\"))] | length < 2))'"
    ],
    "data": [
      {
        "input": [
          {
            "title": "foo",
            "label": [
              "bar-one",
              "bare-two"
            ]
          },
          {
            "title": "foo_42",
            "label": [
              "bar-one",
              "bare-two"
            ]
          },
          {
            "title": "foo_42",
            "label": [
              "bar-one"
            ]
          }
        ],
        "output": [
          {
            "title": "foo_42",
            "label": [
              "bar-one"
            ]
          }
        ]
      }
    ],
    "identifier": 61079552
  },
  {
    "context": [
      "The plan is to be able to pass into my JQ command the Id of one of these and get back out a list.",
      "Eg:\n\nInput: `abc`  \nExpected Output: `[]`\n\nInput: `def`  \nExpected Output: `[\"abc\"]`\n\nInput: `ghi`  \nExpected Output: `[\"abc\", \"def\"]`",
      "Is there a way of constructing this within JQ or do I need to move out to a different language?",
      "Reduce your input JSON down to an object where each Id and corresponding Dependencies array are paired, and walk through it aggregating dependencies using a recursive function.",
      "def deps($depdb; $id):\n  def _deps($id): $depdb[$id] // empty\n    | . + map(_deps(.)[]);\n  _deps($id);\ndeps(map({(.Id): .Dependencies}) | add; $fid)",
      "the output for various values of START is:\nabc   []\ndef   [\"abc\"]\nghi   [\"def\", \"abc\"]"
    ],
    "utterance": "Return the complete list of dependencies (in order of traversal) for a given input Id from a structure where each item may depend on one or more other items.",
    "expressions": [
      "def deps($depdb; $id):\n  def _deps($id): $depdb[$id] // empty\n    | . + map(_deps(.)[]);\n  _deps($id);\ndeps(map({(.Id): .Dependencies}) | add; $fid)",
      "def dependents($x):\n  (map( {(.Id): .Dependencies}) | add) as $next\n  | def tc($x):\n    ($next[$x] - .) as $new\n    | if $new == [] then .\n      else (. + $new | unique)\n      | . + ([tc($new[])[]] - .)\n      end ;\n  [] | tc($x);\n\ndependents($start)"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "abc",
            "Dependencies": []
          },
          {
            "Id": "def",
            "Dependencies": [
              "abc"
            ]
          },
          {
            "Id": "ghi",
            "Dependencies": [
              "def"
            ]
          }
        ],
        "output": {
          "abc": [],
          "def": [
            "abc"
          ],
          "ghi": [
            "def",
            "abc"
          ]
        }
      }
    ],
    "identifier": 61345911
  },
  {
    "context": [
      "I want one file",
      "That looks like:",
      "[",
      "  {",
      "    \"name\": \"Xiaoming\"",
      "  },",
      "  {",
      "    \"name\": \"Xiaoming\"",
      "  }",
      "]",
      "An array of all the other files.",
      "jq -s '.'' file-{1..50}.json > file-all.json",
      "jq -n '[inputs]' file-{1..50}.json > file-all.json"
    ],
    "utterance": "Combine multiple files, each containing an object with a name key, into a single array containing all objects.",
    "expressions": [
      "jq -s '.' file-{1..50}.json",
      "jq -n '[inputs]' file-{1..50}.json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "john"
          },
          {
            "name": "Xiaoming"
          }
        ],
        "output": [
          {
            "name": "john"
          },
          {
            "name": "Xiaoming"
          }
        ]
      }
    ],
    "identifier": 61240118
  },
  {
    "context": [
      "I want to print an output that has the fields VolumeId,Size,Name only when Name tag exists",
      "How can the jq query be changed to get something like\nvol-123,20,abc\nvol-456,22,def",
      "jq -r '.Volumes[] | [.VolumeId, .Size, (.Tags[] | select(.Key == \"Name\").Value)] | join(\",\")'",
      "jq -r '.Volumes[] | select(any(.Tags[]; .Key == \"Name\")) | [.VolumeId,.Size,(.Tags[] | select(.Key == \"Name\").Value)]|join(\",\")'"
    ],
    "utterance": "Extract VolumeId, Size, and the Value of the Name tag for each volume, but only include records where the Name tag exists.",
    "expressions": [
      ".Volumes[] | select(any(.Tags[]; .Key == \"Name\")) | [.VolumeId,.Size,(.Tags[] | select(.Key == \"Name\").Value)] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "Tags": [
                {
                  "Value": "abc",
                  "Key": "Name"
                },
                {
                  "Value": "123",
                  "Key": "App"
                }
              ],
              "Encrypted": false,
              "VolumeType": "gp2",
              "VolumeId": "vol-123",
              "State": "in-use",
              "Iops": 100,
              "SnapshotId": "snap-123",
              "CreateTime": "2019-08-27T00:51:00.971Z",
              "Size": 20
            },
            {
              "Tags": [
                {
                  "Value": "def",
                  "Key": "Name"
                },
                {
                  "Value": "456",
                  "Key": "App"
                }
              ],
              "Encrypted": false,
              "VolumeType": "gp2",
              "VolumeId": "vol-456",
              "State": "in-use",
              "Iops": 100,
              "SnapshotId": "snap-456",
              "CreateTime": "2019-08-27T00:51:00.971Z",
              "Size": 22
            },
            {
              "Tags": [
                {
                  "Value": "789",
                  "Key": "App"
                }
              ],
              "Encrypted": false,
              "VolumeType": "gp2",
              "VolumeId": "vol-789",
              "State": "in-use",
              "Iops": 100,
              "SnapshotId": "snap-789",
              "CreateTime": "2019-08-27T00:51:00.971Z",
              "Size": 23
            }
          ]
        },
        "output": [
          "vol-123,20,abc",
          "vol-456,22,def"
        ]
      }
    ],
    "identifier": 61385715
  },
  {
    "context": [
      "From file1 how can i compare file2  for common \"name\" variables present and also if any field is missing in file2 than file1, how can I get that.",
      "After comparing file1 to file2 , I need to get output like `\"name\": \"SES_TO_EMAIL\"` is not present in file2.",
      "Assuming each file contains a stream of objects, a simple [tag:JQ] program as below would do the trick.",
      "reduce inputs.name as $name ({}; .[input_filename] += [$name])\n| (keys_unsorted | combinations(2)) as $pair\n| (.[$pair[0]] - .[$pair[1]])[]\n| \"name: \\(.) is not present in \\($pair[1])\""
    ],
    "utterance": "List all name fields from the first file that are missing in the second file.",
    "expressions": [
      "reduce inputs.name as $name ({}; .[input_filename] += [$name])\n| (keys_unsorted | combinations(2)) as $pair\n| (.[$pair[0]] - .[$pair[1]])[]\n| \"name: \\(.) is not present in \\($pair[1])\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "SES_ENABLED",
            "value": "true"
          },
          {
            "name": "SES_ADDRESS",
            "value": "email-xxxxxx.aws.com"
          },
          {
            "name": "SES_FROM_EMAIL",
            "value": "abc@gmail.com"
          },
          {
            "name": "SES_TO_EMAIL",
            "value": "123@gmail.com"
          }
        ]
      },
      {
        "input": [
          {
            "name": "SES_ENABLED",
            "value": "false"
          },
          {
            "name": "SES_FROM_EMAIL",
            "value": "xyz@gmail.com"
          },
          {
            "name": "SES_ADDRESS",
            "value": "emails-xyzyzyz.aws.com"
          }
        ],
        "output": [
          "name: SES_TO_EMAIL is not present in file2"
        ]
      }
    ],
    "identifier": 61264414
  }
]