[
  {
    "context": [
      "I get an error:\n\n> parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 276249, column 317",
      "I found that the character that jq can't parse is \\u2022. I tried adding \"-r\" jq command but the error stil occurs. How can I handle this for all occurrences of \\u2022?",
      "Here's verification that `\\u2022` is properly handled by various versions of jq in a Mac environment:",
      "$ echo '\"\\u2022\"' | jq-1.4 .\n\"\u2022\""
    ],
    "utterance": "Process an input containing the character \\u2022 without causing a parsing error.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": "\"\\u2022\"",
        "output": "\"\u2022\""
      }
    ],
    "identifier": 53352558
  },
  {
    "context": [
      "I want to get the values of tags with the key ENVIRONMENT using `jq`:",
      "But as it turned out, the key could be also `Environment`.",
      "How to get both of those tags?",
      "You can use the following command:\r\n\r\n    jq '.TagList[]|select(.Key==\"Environment\" or .Key==\"ENVIRONMENT\").Value'",
      "Generalizing a bit:\r\n    .TagList[]\n    | select(.Key | ascii_upcase == \"ENVIRONMENT\").Value"
    ],
    "utterance": "Extract the values of all tags whose Key is either 'Environment' or 'ENVIRONMENT'.",
    "expressions": [
      ".TagList[] | select(.Key==\"Environment\" or .Key==\"ENVIRONMENT\").Value",
      ".TagList[] | select(.Key | ascii_upcase == \"ENVIRONMENT\").Value"
    ],
    "data": [
      {
        "input": {
          "TagList": [
            {
              "Key": "Environment",
              "Value": "foo"
            },
            {
              "Key": "ENVIRONMENT",
              "Value": "bar"
            }
          ]
        },
        "output": [
          "foo",
          "bar"
        ]
      }
    ],
    "identifier": 53448845
  },
  {
    "context": [
      "echo '{\"foo\": \"bar\"}' | jq '{other: .}' | jq -Rs '{json: .}'",
      "produces:\n\n    {\n      \"json\": \"{\\n  \\\"other\\\": {\\n    \\\"foo\\\": \\\"bar\\\"\\n  }}\\n\"\n    }",
      "One way to remove the terminating \"\\n\" would be to strip it:\n\n    echo '{\"foo\": \"bar\"}' | jq '{other: .}' | jq -Rs '{json: .[:-1]}'",
      "I ended up writing a simple formatting function:\n\ndef pretty:\n  explode | reduce .[] as $char (\n    {out: [], indent: [], string: false, escape: false};\n    if .string == true then\n      .out += [$char]\n      | if $char == 34 and .escape == false then .string = false else . end\n      | if $char == 92 and .escape == false then .escape = true else .escape = false end\n    elif $char == 91 or $char == 123 then\n      .indent += [32, 32] | .out += [$char, 10] + .indent\n    elif $char == 93 or $char == 125 then\n      .indent = .indent[2:] | .out += [10] + .indent + [$char]\n    elif $char == 34 then\n      .out += [$char] | .string = true\n    elif $char == 58 then\n      .out += [$char, 32]\n    elif $char == 44 then\n      .out += [$char, 10] + .indent\n    elif $char == 9 or $char == 10 or $char == 13 or $char == 32 then\n      .\n    else\n      .out += [$char]\n    end\n  ) | .out | implode;"
    ],
    "utterance": "Embed a prettily formatted object as a string value under the key 'json', preserving indentation and newlines.",
    "expressions": [
      "echo '{\"foo\": \"bar\"}' | jq '{other: .}' | jq -Rs '{json: .}'",
      "echo '{\"foo\": \"bar\"}' | jq '{other: .}' | jq -Rs '{json: .[:-1]}'",
      "// In a jq file:\ndef pretty:\n  explode | reduce .[] as $char (\n    {out: [], indent: [], string: false, escape: false};\n    if .string == true then\n      .out += [$char]\n      | if $char == 34 and .escape == false then .string = false else . end\n      | if $char == 92 and .escape == false then .escape = true else .escape = false end\n    elif $char == 91 or $char == 123 then\n      .indent += [32, 32] | .out += [$char, 10] + .indent\n    elif $char == 93 or $char == 125 then\n      .indent = .indent[2:] | .out += [10] + .indent + [$char]\n    elif $char == 34 then\n      .out += [$char] | .string = true\n    elif $char == 58 then\n      .out += [$char, 32]\n    elif $char == 44 then\n      .out += [$char, 10] + .indent\n    elif $char == 9 or $char == 10 or $char == 13 or $char == 32 then\n      .\n    else\n      .out += [$char]\n    end\n  ) | .out | implode;"
    ],
    "data": [
      {
        "input": {
          "foo": "bar"
        },
        "output": {
          "json": "{\n  \"other\": {\n    \"foo\": \"bar\"\n  }\n}"
        }
      }
    ],
    "identifier": 53346007
  },
  {
    "context": [
      "So my question is how to add these numbers up?",
      "I also tried casting it to array by using `[.pullRequests.totalCount]` but I was unable to merge, meld, join the arrays to get the final count.",
      "[ .data.organization.repositories.nodes[]\n  | .pullRequests.totalCount ]\n| add",
      ".data.organization.repositories.nodes\n| map(.pullRequests.totalCount)\n| add",
      ".data.organization.repositories.nodes\n| sigma(.[].pullRequests.totalCount)"
    ],
    "utterance": "Sum the totalCount values of all pullRequests in each repository node under data.organization.repositories.nodes.",
    "expressions": [
      "[ .data.organization.repositories.nodes[] | .pullRequests.totalCount ] | add",
      ".data.organization.repositories.nodes | map(.pullRequests.totalCount) | add",
      "def sigma(s): reduce s as $s (null; .+$s); .data.organization.repositories.nodes | sigma(.[].pullRequests.totalCount)"
    ],
    "data": [
      {
        "input": {
          "data": {
            "organization": {
              "repositories": {
                "nodes": [
                  {
                    "pullRequests": {
                      "totalCount": 2
                    }
                  },
                  {
                    "pullRequests": {
                      "totalCount": 8
                    }
                  },
                  {
                    "pullRequests": {
                      "totalCount": 23
                    }
                  }
                ]
              }
            }
          }
        },
        "output": 33
      }
    ],
    "identifier": 53434228
  },
  {
    "context": [
      "Here\u2019s one approach:\r\n\r\n    $ jq -c -n '[ $a, $b, $c ] | transpose'  --slurpfile a a.txt  --slurpfile b b.txt  --slurpfile c c.txt",
      "If you want to gather the entire result into a single array, pipe it into another instance of jq in slurp mode. (There's probably a way to do it with a single invocation of jq, but this seems simpler.)\r\n\r\n    $ paste a.txt b.txt c.txt | jq -R 'split(\"\\t\") | map(tonumber)' | jq -sc\r\n    [[20,19,2],[3,4,4],[10,5,9],[15,8,21],[15,8,5]]",
      "Generalization to an arbitrary number of files\r\n\r\nIn the following, we'll assume that the files to be processed can be specified by *.txt in the current directory:\r\n\r\n    jq -n -c '[reduce inputs as $i ({}; .[input_filename] += [$i]) | .[]] | transpose' *.txt"
    ],
    "utterance": "Create an array where each element contains values from the same line number across multiple files, so that the first subarray contains all first-line values from each file, the second contains all second-line values, and so on.",
    "expressions": [
      "jq -c -n '[ $a, $b, $c ] | transpose' --slurpfile a a.txt --slurpfile b b.txt --slurpfile c c.txt",
      "jq -n -c '[reduce inputs as $i ({}; .[input_filename] += [$i]) | .[]] | transpose' *.txt",
      "paste a.txt b.txt c.txt | jq -R 'split(\"\\t\") | map(tonumber)' | jq -sc"
    ],
    "data": [
      {
        "input": {
          "a.txt": [
            20,
            3,
            10,
            15,
            15
          ],
          "b.txt": [
            19,
            4,
            5,
            8,
            8
          ],
          "c.txt": [
            2,
            4,
            9,
            21,
            5
          ]
        },
        "output": [
          [
            20,
            19,
            2
          ],
          [
            3,
            4,
            4
          ],
          [
            10,
            5,
            9
          ],
          [
            15,
            8,
            21
          ],
          [
            15,
            8,
            5
          ]
        ]
      }
    ],
    "identifier": 53439594
  },
  {
    "context": [
      "With your `jq` command you never specify the sub-key to return the value, it should be:",
      "jq '.fileMetadata.ref_Version' re.json",
      "**Output:**",
      "\"125\"",
      "if databaseName=$(getJson user@address /data/Doc1/re.json \\",
      "                    | jq -r '.fileMetadata.ref_Version'); then",
      "Similarly, [as noted by l'L'l](https://stackoverflow.com/a/53343072/14122), your JSON needs some fixes to be well-formed. `{ \"fileMetadata\": { \"ref_Version\": \"125\" } }` is a valid reformulation."
    ],
    "utterance": "Extract the value of the field ref_Version nested under fileMetadata in the data file.",
    "expressions": [
      ".fileMetadata.ref_Version",
      "-r '.fileMetadata.ref_Version'"
    ],
    "data": [
      {
        "input": {
          "fileMetadata": {
            "ref_Version": "125"
          }
        },
        "output": "125"
      }
    ],
    "identifier": 53339451
  },
  {
    "context": [
      "The goals is to iterate over each instances and map the `Tags.Value` (select on `.Key==\"Name\"`) and the `.Ebs.VolumeId`.",
      "Expected output is :\n\n    FOO - DEV - BAR - instance-name:vol-fffffffffffff",
      "(.Reservations[].Instances[]) as $root\n| ($root.Tags? | .[] | select(.Key==\"Name\") | .Value) + \":\" \n  + ($root.BlockDeviceMappings? | .[].Ebs.VolumeId) ",
      "(.Reservations[].Instances[])\n| (.Tags? | .[] | select(.Key==\"Name\").Value) + \":\" \n  + (.BlockDeviceMappings? | .[].Ebs.VolumeId) "
    ],
    "utterance": "For each instance, output the value of the tag with Key \"Name\" concatenated with the VolumeId of each EBS block device, separated by a colon.",
    "expressions": [
      "(.Reservations[].Instances[]) as $root | ($root.Tags? | .[] | select(.Key==\"Name\") | .Value) + \":\" + ($root.BlockDeviceMappings? | .[].Ebs.VolumeId)",
      "(.Reservations[].Instances[]) | (.Tags? | .[] | select(.Key==\"Name\").Value) + \":\" + (.BlockDeviceMappings? | .[].Ebs.VolumeId)"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/xvda",
                      "Ebs": {
                        "DeleteOnTermination": true,
                        "VolumeId": "vol-fffffffffffff"
                      }
                    }
                  ],
                  "Tags": [
                    {
                      "Value": "FOO - DEV - BAR - instance-name",
                      "Key": "Name"
                    }
                  ]
                }
              ],
              "ReservationId": "r-xxxx"
            }
          ]
        },
        "output": [
          "FOO - DEV - BAR - instance-name:vol-fffffffffffff"
        ]
      }
    ],
    "identifier": 53520227
  },
  {
    "context": [
      "I merge the code using the following code:\r\n\r\n    cat genesis.json.src | jq --arg pub_key $PK --arg name node$i --arg addr $ADDR '.validators+= [{address: $addr, pub_key: $pub_key, power:\"10\",name:$name}]' > genesis.json.dest",
      "this is colour sequence characters. I removed them by adding a -M flag for JQ that disables colours."
    ],
    "utterance": "Append a new element to the validators array without introducing color escape characters into the string fields.",
    "expressions": [
      "jq -M --arg pub_key \"$PK\" --arg name \"node$i\" --arg addr \"$ADDR\" '.validators += [{address: $addr, pub_key: $pub_key, power:\"10\",name:$name}]'"
    ],
    "identifier": 53432500
  },
  {
    "context": [
      "Now I want to select all active items, and create for each a single line describing the item's ID as well as the value of both its `foo` and `bar` tags.",
      "But because `bar` is only included in item `B`, the line for item `A` gets filtered out.",
      "Is there a way to make the sub-select optional so that if the select fails, I get an empty string or something like that?",
      "Variant using `first` and string interpolation",
      ".items[] | select ( .active == true ) | (first(.tags[] | select(.name == \"foo\") | .value) // \"\")  as $v | (first(.tags[] | select(.name == \"bar\") | .value) // \"\")  as $w | \"\\(.id) -> [\\($v), \\($w)]\""
    ],
    "utterance": "For each active item, output a line with its id, the value of its tag named 'foo', and the value of its tag named 'bar', inserting an empty string if either tag is missing.",
    "expressions": [
      ".items[]\n| select ( .active == true )\n| (first(.tags[] | select(.name == \"foo\") | .value) // \"\")  as $v\n| (first(.tags[] | select(.name == \"bar\") | .value) // \"\")  as $w\n| \"\\(.id) -> [\\($v), \\($w)]\""
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "A",
              "active": true,
              "tags": [
                {
                  "name": "foo",
                  "value": 1
                }
              ]
            },
            {
              "id": "B",
              "active": true,
              "tags": [
                {
                  "name": "foo",
                  "value": 1
                },
                {
                  "name": "bar",
                  "value": 2
                }
              ]
            },
            {
              "id": "C",
              "active": false,
              "tags": [
                {
                  "name": "foo",
                  "value": 1
                },
                {
                  "name": "baz",
                  "value": 3
                }
              ]
            }
          ]
        },
        "output": [
          "A -> [1, ]",
          "B -> [1, 2]"
        ]
      }
    ],
    "identifier": 53339194
  },
  {
    "context": [
      "Need to get from this list only duplicates per first value:",
      "\"mydomain.com 125.125.125.125\"",
      "\"mydomain.com 125.125.125.126\"",
      "\"mydomain.com 125.125.125.127\"",
      "\"static.mydomain.com 124.124.124.124\"",
      "\"static.mydomain.com 124.124.124.128\"",
      "map(split(\" \"))\n| aggregate_by(.[0]; .[1])\n| with_entries(select(.value|length > 1))\n| to_entries[]\n| .key as $k | .value[] | [$k, .]\n| join(\" \")"
    ],
    "utterance": "Return all entries where the first field occurs more than once in the list, preserving all such entries.",
    "expressions": [
      "map(split(\" \"))\n| aggregate_by(.[0]; .[1])\n| with_entries(select(.value|length > 1))\n| to_entries[]\n| .key as $k | .value[] | [$k, .]\n| join(\" \")"
    ],
    "data": [
      {
        "input": [
          "test.mydomain.com 123.123.123.123",
          "static.mydomain.com 124.124.124.124",
          "static.mydomain.com 124.124.124.128",
          "mydomain.com 125.125.125.125",
          "mydomain.com 125.125.125.126",
          "mydomain.com 125.125.125.127"
        ],
        "output": [
          "static.mydomain.com 124.124.124.124",
          "static.mydomain.com 124.124.124.128",
          "mydomain.com 125.125.125.125",
          "mydomain.com 125.125.125.126",
          "mydomain.com 125.125.125.127"
        ]
      }
    ],
    "identifier": 53553637
  },
  {
    "context": [
      "What I want to extract from above output is:\r\n\r\n    submit Records:\r\n    \r\n    label:Verified status:OK name:ADP Automation\r\n    lable:Code-Review status:OK name:abc\r\n\r\nThat is the only information I need to display/store in csv file.",
      "You could use the jq program like in the following example:\r\n\r\n    ssh -p 29418 gerrit.abc.se gerrit query --format=JSON project:dddd status:merged branch:master change:Ie2ef9e47f --submit-records |\r\n     jq --raw-output '       .submitRecords[]?        | .labels[]       | .label + \" = \" + .status + \" by \" + .by.name'"
    ],
    "utterance": "Extract the label, status, and by.name fields for each label in all submitRecords and display them together.",
    "expressions": [
      ".submitRecords[]? | .labels[] | .label + \":\" + .status + \" name:\" + .by.name",
      ".submitRecords[]? | .labels[] | [ .label, .status, .by.name ] | @csv"
    ],
    "data": [
      {
        "input": {
          "project": "dddd",
          "branch": "master",
          "id": "Ie2ef9e47fc6c046091d93521198bf0a1075cb77e",
          "number": 3984134,
          "subject": "adding configuration",
          "owner": {
            "name": "abc",
            "email": "abc.com",
            "username": "eshakuy"
          },
          "url": "https://gerrit.abc.se/3984134",
          "commitMessage": "adding configuration\n\nChange-Id: Ie2ef9e47fc6c046091d93521198bf0a1075cb77e\n",
          "createdOn": 1533208993,
          "lastUpdated": 1536301464,
          "open": false,
          "status": "MERGED",
          "submitRecords": [
            {
              "status": "OK",
              "labels": [
                {
                  "label": "Verified",
                  "status": "OK",
                  "by": {
                    "name": "ADP Automation",
                    "username": "adpauto"
                  }
                },
                {
                  "label": "Code-Review",
                  "status": "OK",
                  "by": {
                    "name": "abc",
                    "email": "abc.com",
                    "username": "eeeee"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          "Verified:OK name:ADP Automation",
          "Code-Review:OK name:abc"
        ]
      }
    ],
    "identifier": 53169040
  },
  {
    "context": [
      "I get what i want. But if I use \r\n\r\n    jq 'INDEX(input; .a + \":\" + .b) data.json\r\n\r\nthen I get the error\r\n\r\n    jq: error (at data.json:<last-line>): break",
      "Adding input (data.json): \r\n\r\n    [\r\n    \t{\r\n    \t\t\"a\": \"a1\",\r\n    \t\t\"b\": \"b1\",\r\n    \t\t\"c\": \"c1\",\r\n    \t\t\"d\": \"d1\"\r\n    \t},\r\n    \t{\r\n    \t\t\"a\": \"a2\",\r\n    \t\t\"b\": \"b2\",\r\n    \t\t\"c\": \"c2\",\r\n    \t\t\"d\": \"d2\"\r\n    \t},\r\n    \t{\r\n    \t\t\"a\": \"a3\",\r\n    \t\t\"b\": \"b3\",\r\n    \t\t\"c\": \"c3\",\r\n    \t\t\"d\": \"d3\"\r\n    \t}\r\n    ]",
      "And expected output\r\n\r\n    {\r\n      \"a1:b1\": {\r\n        \"a\": \"a1\",\r\n        \"b\": \"b1\",\r\n        \"c\": \"c1\",\r\n        \"d\": \"d1\"\r\n      },\r\n      \"a2:b2\": {\r\n        \"a\": \"a2\",\r\n        \"b\": \"b2\",\r\n        \"c\": \"c2\",\r\n        \"d\": \"d2\"\r\n      },\r\n      \"a3:b3\": {\r\n        \"a\": \"a3\",\r\n        \"b\": \"b3\",\r\n        \"c\": \"c3\",\r\n        \"d\": \"d3\"\r\n      }\r\n    }",
      "The first argument of `INDEX/2` should be a stream of the items to be indexed; here, `.[]` is exactly what we want:\r\n\r\n    INDEX(.[]; .a + \":\" + .b) ",
      "For jq version 1.5 or older, `INDEX` does not seem to be working (does not exist?), but this works instead:\r\n\r\n```\r\njq 'map({key: (.a + \":\" + .b), value: .}) | from_entries' data.json\r\n```"
    ],
    "utterance": "Produce an object mapping each item's a and b properties joined by ':' to that item itself, using a list of objects as input.",
    "expressions": [
      "INDEX(.[]; .a + \":\" + .b)",
      "map({key: (.a + \":\" + .b), value: .}) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "a": "a1",
            "b": "b1",
            "c": "c1",
            "d": "d1"
          },
          {
            "a": "a2",
            "b": "b2",
            "c": "c2",
            "d": "d2"
          },
          {
            "a": "a3",
            "b": "b3",
            "c": "c3",
            "d": "d3"
          }
        ],
        "output": {
          "a1:b1": {
            "a": "a1",
            "b": "b1",
            "c": "c1",
            "d": "d1"
          },
          "a2:b2": {
            "a": "a2",
            "b": "b2",
            "c": "c2",
            "d": "d2"
          },
          "a3:b3": {
            "a": "a3",
            "b": "b3",
            "c": "c3",
            "d": "d3"
          }
        }
      }
    ],
    "identifier": 53276988
  },
  {
    "context": [
      "What I now want are alle tradeIds where the rating is 84.",
      "But with this filter I&#39;m inside the itemData and have no access to the tradeId which I&#39;m interested for.",
      "I think all you need to do is below. The logic is you need to list all array objects, filter on the rating value to get the subset and print the `tradeId` for those objects",
      "jq '.auctionInfo[] | select(.itemData.rating == 84).tradeId'"
    ],
    "utterance": "Return all tradeIds where the corresponding item's rating equals 84.",
    "expressions": [
      ".auctionInfo[] | select(.itemData.rating == 84).tradeId"
    ],
    "data": [
      {
        "input": {
          "auctionInfo": [
            {
              "tradeId": 229143000306,
              "itemData": {
                "id": 320854114832,
                "rating": 82
              }
            },
            {
              "tradeId": 229143000307,
              "itemData": {
                "id": 320854114833,
                "rating": 84
              }
            },
            {
              "tradeId": 229143000308,
              "itemData": {
                "id": 320854114834,
                "rating": 84
              }
            }
          ]
        },
        "output": [
          229143000307,
          229143000308
        ]
      }
    ],
    "identifier": 53337311
  },
  {
    "context": [
      "i want only the values of the credentials field xxxxxxxxxxxxxx111 and xxxxxxxxxxxx2222",
      "You can use this `jq` filter:\r\n\r\n    jq -r '.credentials|to_entries|.[]|.key' file"
    ],
    "utterance": "List the keys of the credentials object.",
    "expressions": [
      ".credentials | to_entries | .[] | .key"
    ],
    "data": [
      {
        "input": {
          "credentials": {
            "xxxxxxxxxxxxxx111": {},
            "xxxxxxxxxxxx2222": {}
          },
          "description": "All credentials that are not bound to a specific domain.",
          "displayName": "Global credentials",
          "fullDisplayName": "Credentials \u00bb Global credentials",
          "fullName": "credential-store/_",
          "global": true,
          "urlName": "_"
        },
        "output": [
          "xxxxxxxxxxxxxx111",
          "xxxxxxxxxxxx2222"
        ]
      }
    ],
    "identifier": 53265018
  },
  {
    "context": [
      "I use following jq command to transform the data:\r\n\r\n    [.legs[] | {Legid: .legId, Farecode: .fareBasisCode, Travelduration: .travelDuration, Traveldistance: .totalTravelDistance, Distanceunit: .totalTravelDistanceUnits, Refundable: .isRefundable , Nonstop: .isNonStop, Departure_Airport: .segments[].departureAirportName, Departure_Code: .segments[].departureAirportCode, Arrival_Airport: .segments[].arrivalAirportName, Arrival_Code: .segments[].arrivalAirportCode, Departure_Time: .segments[].departureTimeEpochSeconds, Arrival_Time: .segments[].arrivalTimeEpochSeconds, Airline: .segments[].airlineName, Airline_Code: .segments[].airlineCode, Flight_Number: .segments[].flightNumber, Equipment: .segments[].equipmentDescription}]",
      "So i modified the command:\r\n\r\n    [.legs[] | {Legid: .legId, Farecode: .fareBasisCode, Travelduration: .travelDuration, Traveldistance: .totalTravelDistance, Distanceunit: .totalTravelDistanceUnits, Refundable: .isRefundable , Nonstop: .isNonStop, Departure_Airport: .segments[].departureAirportName, Departure_Code: .segments[].departureAirportCode, Arrival_Airport: .segments[].arrivalAirportName, Arrival_Code: .segments[].arrivalAirportCode, Departure_Time: .segments[].departureTimeEpochSeconds, Arrival_Time: .segments[].arrivalTimeEpochSeconds, Airline: .segments[].airlineName, Airline_Code: .segments[].airlineCode, Flight_Number: .segments[].flightNumber, Equipment: .segments[].equipmentDescription}] | .[].Departure_Time |= todate | .[].Arrival_Time |= todate",
      "Your use of iteration (`.segments[]`) causes multiplicative behavior: in your case, since there are four cases in which `.segments|length` is 2, you get a 2^10 expansion locally, four times.",
      "Perhaps what you intended is something more like:\r\n\r\n    [ .legs[] | range(0; .segments|length) as $i | .... ]"
    ],
    "utterance": "Extract leg and segment fields, including segment details by index to avoid data expansion, and convert Departure_Time and Arrival_Time (which are UNIX timestamps) to dates.",
    "expressions": [
      "[.legs[] | range(0; .segments|length) as $i | {Legid: .legId, Farecode: .fareBasisCode, Travelduration: .travelDuration, Traveldistance: .totalTravelDistance, Distanceunit: .totalTravelDistanceUnits, Refundable: .isRefundable, Nonstop: .isNonStop, Departure_Airport: .segments[$i].departureAirportName, Departure_Code: .segments[$i].departureAirportCode, Arrival_Airport: .segments[$i].arrivalAirportName, Arrival_Code: .segments[$i].arrivalAirportCode, Departure_Time: (.segments[$i].departureTimeEpochSeconds | todate), Arrival_Time: (.segments[$i].arrivalTimeEpochSeconds | todate), Airline: .segments[$i].airlineName, Airline_Code: .segments[$i].airlineCode, Flight_Number: .segments[$i].flightNumber, Equipment: .segments[$i].equipmentDescription}]"
    ],
    "identifier": 53296285
  },
  {
    "context": [
      "I want to get the value in a json dictionary and for that I have to use variables. I am entering this command:\n    echo $rulebase | jq --arg n \"$0\" '.rulebase[$n].to'\nand I get the next error:\n>jq: error: Cannot index array with string",
      "You need to pass numbers as JSON args. Here\n    echo \"$rulebase\" | jq --argjson n \"$my_variable\" '.rulebase[$n].to'",
      "If you want to pass in a numeric value, use\n    \u2014-argjson\n\ninstead of `\u2014-arg`, which is for JSON string values.",
      "otherwise, you could use `tonumber`.",
      "You need to convert the string that you give to your script to a _number_.\n    echo \"$rulebase\" | jq --arg n \"$1\" '.rulebase[$n|tonumber].to'"
    ],
    "utterance": "Retrieve the value of the 'to' field from the nth element of the 'rulebase' array, where n is supplied as a variable.",
    "expressions": [
      ".rulebase[$n].to",
      ".rulebase[$n|tonumber].to"
    ],
    "identifier": 53261746
  },
  {
    "context": [
      "And what I need is to extract this : datanode, toto, etc. Only the name.",
      "You can use jq's `keys` functionality",
      "jq 'keys' file.json",
      "A more fitting title for the question would have been: \"How to get all top level keys of json data using jq?\"",
      "provide a complete and valid example structure and the expected result like this:\n{\n  \"one_key\": {\n    \"foo\": \"bar\"\n  },\n  \"another_one\": {\n    \"bla\": \"bla\"\n  }\n}\nAnd desired result:\n[\n  \"another_one\",\n  \"one_key\"\n]"
    ],
    "utterance": "Extract all top-level key names from an object, such as 'datanode' and 'toto'.",
    "expressions": [
      "keys"
    ],
    "data": [
      {
        "input": {
          "one_key": {
            "foo": "bar"
          },
          "another_one": {
            "bla": "bla"
          }
        },
        "output": [
          "another_one",
          "one_key"
        ]
      }
    ],
    "identifier": 53337072
  },
  {
    "context": [
      "I filter it with that:\n\n`cat $DEFAULTS_FILE | jq .users`\n\nI have no clue how to convert that json into a yaml.",
      "As I understand it, scalar values are just output as is (with potential encoding), objects are output as key/value pairs, and array objects are output with a `-` for every item. The indentation associates what's part of what.\n\nSo based on those rules if you're going to use jq:\n\ndef yamlify:\n    (objects | to_entries[] | (.value | type) as $type |\n        if $type == \"array\" then\n            \"\\(.key):\",\n            (.value | yamlify)\n        elif $type == \"object\" then\n            \"\\(.key):\",\n            \"    \\(.value | yamlify)\"\n        else\n            \"\\(.key):\\t\\(.value)\"\n        end\n    )\n    // (arrays | select(length > 0)[] | [yamlify] |\n        \"  - \\(.[0])\",\n        \"    \\(.[1:][])\"\n    )\n    // .\n    ;",
      "Then to use it, add it to your `.jq` file and use it:\n\n    $ jq -r yamlify input.json\n    users:\n      - name:       pi\n        gecos:      Hypriot Pirate\n        sudo:       ALL=(ALL) NOPASSWD:ALL\n        shell:      /bin/bash\n        groups:     users,docker,video\n        plain_text_passwd:  pi\n        lock_passwd:        false\n        ssh_pwauth: true\n        chpasswd:\n            expire: false\n      - name:       admin\n        gecos:      Hypriot Pirate\n        sudo:       ALL=(ALL) NOPASSWD:ALL\n        shell:      /bin/bash\n        primary-group:      users\n        groups:     users,docker,adm,dialout,audio,plugdev,netdev,video\n        ssh-import-id:      None\n        plain_text_passwd:  pi\n        lock_passwd:        true\n        ssh_pwauth: true\n        chpasswd:   {expire: false}\n        ssh-authorized-keys:\n          - ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local"
    ],
    "utterance": "Convert a 'users' array with user objects to YAML format, including nested objects and arrays, preserving indentation and list structure.",
    "expressions": [
      "def yamlify:\n    (objects | to_entries[] | (.value | type) as $type |\n        if $type == \"array\" then\n            \"\\(.key):\",\n            (.value | yamlify)\n        elif $type == \"object\" then\n            \"\\(.key):\",\n            \"    \\(.value | yamlify)\"\n        else\n            \"\\(.key):\\t\\(.value)\"\n        end\n    )\n    // (arrays | select(length > 0)[] | [yamlify] |\n        \"  - \\(.[0])\",\n        \"    \\(.[1:][])\"\n    )\n    // .\n    ;\n\njq -r yamlify input.json"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "name": "pi",
              "gecos": "Hypriot Pirate",
              "sudo": "ALL=(ALL) NOPASSWD:ALL",
              "shell": "/bin/bash",
              "groups": "users,docker,video",
              "plain_text_passwd": "pi",
              "lock_passwd": "false",
              "ssh_pwauth": "true",
              "chpasswd": {
                "expire": false
              }
            },
            {
              "name": "admin",
              "gecos": "Hypriot Pirate",
              "sudo": "ALL=(ALL) NOPASSWD:ALL",
              "shell": "/bin/bash",
              "primary-group": "users",
              "groups": "users,docker,adm,dialout,audio,plugdev,netdev,video",
              "ssh-import-id": "None",
              "plain_text_passwd": "pi",
              "lock_passwd": "true",
              "ssh_pwauth": "true",
              "chpasswd": "{expire: false}",
              "ssh-authorized-keys": [
                "ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local"
              ]
            }
          ]
        },
        "output": "users:\n  - name:       pi\n    gecos:      Hypriot Pirate\n    sudo:       ALL=(ALL) NOPASSWD:ALL\n    shell:      /bin/bash\n    groups:     users,docker,video\n    plain_text_passwd:  pi\n    lock_passwd:        false\n    ssh_pwauth: true\n    chpasswd:\n        expire: false\n  - name:       admin\n    gecos:      Hypriot Pirate\n    sudo:       ALL=(ALL) NOPASSWD:ALL\n    shell:      /bin/bash\n    primary-group:      users\n    groups:     users,docker,adm,dialout,audio,plugdev,netdev,video\n    ssh-import-id:      None\n    plain_text_passwd:  pi\n    lock_passwd:        true\n    ssh_pwauth: true\n    chpasswd:   {expire: false}\n    ssh-authorized-keys:\n      - ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local"
      }
    ],
    "identifier": 53315791
  },
  {
    "context": [
      "But if i execute this command:\n\n    cat <file> | jq -r '.env_vars' | jq -r 'keys[] as $k | \"\\($k)=\\\"\\(.[$k])\\\"\"'\n\nThe result is:\n\n    TERRAFORM_CFG_TLS_CERT: \"-----BEGIN CERTIFICATE----\\nMIIIqzCCB5O\"\n\n=> One backslash has been removed... why ?\nHow to avoid this ?",
      "You should output the string as json to preserve the escapes. By taking a string and outputting it raw, you're getting exactly what that string was, a literal backslash followed by an `n`.",
      "$ ... | jq -r '.env_vars | to_entries[] | \"\\(.key): \\(.value | tojson)\"'"
    ],
    "utterance": "Print each key and value from env_vars, ensuring that escape sequences like double backslashes are preserved in the output values.",
    "expressions": [
      ".env_vars | to_entries[] | \"\\(.key): \\(.value | tojson)\""
    ],
    "data": [
      {
        "input": {
          "env_vars": {
            "TERRAFORM_CFG_TLS_CERT": "-----BEGIN CERTIFICATE----\\\\nMIIIqzCCB5O"
          }
        },
        "output": "TERRAFORM_CFG_TLS_CERT: \"-----BEGIN CERTIFICATE----\\\\nMIIIqzCCB5O\""
      }
    ],
    "identifier": 53434630
  },
  {
    "context": [
      "I am trying to get the output to look like this with the uri over the tags (trying to transform to csv): ",
      "https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially",
      "fields, jq, multiple",
      "I tried this but the tags are nested ... | jq '.list[] | \"\\(.given_url) \\(.tags)\"'",
      "jq -r '.list[] | [.given_url] + (.tags|keys_unsorted) | @csv' input.json",
      "I added a ?. This works (even for entries without tags).\n\n`curl ... | jq -r '.list[] | [.given_url] + (.tags|keys_unsorted?) | @csv' | less"
    ],
    "utterance": "Output each item's given_url followed by its tag names as CSV columns, omitting double quotes when possible, and handle items even if they have no tags.",
    "expressions": [
      ".list[] | [.given_url] + (.tags|keys_unsorted) | @csv",
      ".list[] | [.given_url] + (.tags|keys_unsorted?) | @csv"
    ],
    "data": [
      {
        "input": {
          "list": {
            "1548784635": {
              "item_id": "1548784635",
              "given_url": "https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially",
              "tags": {
                "fields": {
                  "item_id": "1548784635",
                  "tag": "fields"
                },
                "jq": {
                  "item_id": "1548784635",
                  "tag": "jq"
                },
                "multiple": {
                  "item_id": "1548784635",
                  "tag": "multiple"
                }
              }
            }
          }
        },
        "output": "\"https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially\",\"fields\",\"jq\",\"multiple\""
      }
    ],
    "identifier": 53311375
  },
  {
    "context": [
      "cat myFile.json | jq '.offerVerticalMap[\"GROCERIES.offerPublishStatus\"]'",
      "~$ jq -r '.[].name' n1.json",
      "sandboxserver.tar.gz.part-aa",
      "sandboxserver.tar.gz.part-ab",
      "sandboxserver.tar.gz.part-ac"
    ],
    "utterance": "Extract all values of the 'name' attribute from each object in an array.",
    "expressions": [
      ".[].name",
      "-r '.[].name'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "sandboxserver.tar.gz.part-aa",
            "hash": "010d126f8ccf199f3cd5f468a90d5ae1",
            "bytes": 4294967296,
            "last_modified": "2018-10-10T01:32:00.069000",
            "content_type": "binary/octet-stream"
          },
          {
            "name": "sandboxserver.tar.gz.part-ab",
            "hash": "49a6f22068228f51488559c096aa06ce",
            "bytes": 397973601,
            "last_modified": "2018-10-10T01:32:22.395000",
            "content_type": "binary/octet-stream"
          },
          {
            "name": "sandboxserver.tar.gz.part-ac",
            "hash": "2c5e845f46357e203214592332774f4c",
            "bytes": 5179281858,
            "last_modified": "2018-10-11T08:20:11.566000",
            "content_type": "binary/octet-stream"
          }
        ],
        "output": [
          "sandboxserver.tar.gz.part-aa",
          "sandboxserver.tar.gz.part-ab",
          "sandboxserver.tar.gz.part-ac"
        ]
      }
    ],
    "identifier": 53369090
  },
  {
    "context": [
      "The result I want to achieve, using `jq` preferably, is the following:\r\n\r\n    [\r\n      {\r\n        \"certname\": \"one.example.com\",\r\n        \"fact1\": \"value1\",\r\n        \"fact2\": 42\r\n      },\r\n      {\r\n        \"certname\": \"two.example.com\",\r\n        \"fact1\": \"value3\",\r\n        \"fact2\": 10000,\r\n        \"fact3\": { \"anotherkey\": \"anothervalue\" }\r\n      }\r\n    ]",
      "map( {certname, (.name): .value} )\n| group_by(.certname)\n| map(add)"
    ],
    "utterance": "Group objects by certname and create a new object for each group, merging their fact names as keys assigned to their corresponding values.",
    "expressions": [
      "map({certname, (.name): .value}) | group_by(.certname) | map(add)"
    ],
    "data": [
      {
        "input": [
          {
            "certname": "one.example.com",
            "name": "fact1",
            "value": "value1"
          },
          {
            "certname": "one.example.com",
            "name": "fact2",
            "value": 42
          },
          {
            "certname": "two.example.com",
            "name": "fact1",
            "value": "value3"
          },
          {
            "certname": "two.example.com",
            "name": "fact2",
            "value": 10000
          },
          {
            "certname": "two.example.com",
            "name": "fact3",
            "value": {
              "anotherkey": "anothervalue"
            }
          }
        ],
        "output": [
          {
            "certname": "one.example.com",
            "fact1": "value1",
            "fact2": 42
          },
          {
            "certname": "two.example.com",
            "fact1": "value3",
            "fact2": 10000,
            "fact3": {
              "anotherkey": "anothervalue"
            }
          }
        ]
      }
    ],
    "identifier": 53308984
  },
  {
    "context": [
      "i got this end results of a long shell script i want to convert it to a json object is there's any simple way where i can pipe the echo | in to it",
      "i want to get this results like this json",
      "echo 'name=$get_name\r\n    pass=$get_pass\r\n    value=$get_value\r\n    key=$get_key\r\n    port=$get_port\r\n    server_ip=$get_ip' | jq -Rs '\r\n  split(\"\\n\")\r\n  | map(capture(\"(?<k>^[^=]*)=(?<v>.*)\")  | {(.k): .v} )\r\n  | add'\r\n",
      "produces output in the format you've indicated you want:\r\n\r\n    {\r\n      \"name\": \"$get_name\",\r\n      \"pass\": \"$get_pass\",\r\n      \"value\": \"$get_value\",\r\n      \"key\": \"$get_key\",\r\n      \"port\": \"$get_port\",\r\n      \"server_ip\": \"$get_ip\"\r\n    }"
    ],
    "utterance": "Convert multi-line key=value shell output into an object mapping each key to its value.",
    "expressions": [
      "jq -Rs '\nsplit(\"\\n\")\n| map(capture(\"(?<k>^[^=]*)=(?<v>.*)\")  | {(.k): .v} )\n| add'"
    ],
    "data": [
      {
        "input": "name=foo\npass=bar\nvalue=123\nkey=abc\nport=22\nserver_ip=192.168.1.10",
        "output": {
          "name": "foo",
          "pass": "bar",
          "value": "123",
          "key": "abc",
          "port": "22",
          "server_ip": "192.168.1.10"
        }
      }
    ],
    "identifier": 53292674
  },
  {
    "context": [
      "I have some JSON that I need to filter based on whether certain attribute values are present in an array.",
      "select(.potato as $k | ([1,2,3,4] | any(. == $k)))",
      "[1,2,3,4] as $acceptable\n| .potato as $k\n| select( any($acceptable[];  . == $k) )",
      "[1,2,3,4] as $acceptable\n| select(.potato | IN($acceptable[]))"
    ],
    "utterance": "Filter objects where the value of the potato attribute is contained in the array [1,2,3,4].",
    "expressions": [
      "[1,2,3,4] as $acceptable | .potato as $k | select(any($acceptable[]; . == $k))",
      "[1,2,3,4] as $acceptable | select(.potato | IN($acceptable[]))"
    ],
    "data": [
      {
        "input": {
          "potato": 4
        },
        "output": {
          "potato": 4
        }
      }
    ],
    "identifier": 53307740
  },
  {
    "context": [
      "Create report for each `bar.item` that does **not** have any corresponding `foo.item` with a value `foo_bad`",
      "The output format: `.id, .bar.item.value, .var.item.value`",
      "\"123\",\"bar_value_1a\",\"var_value_1a\"",
      "\"456\",\"bar_value_2b\",\"var_value_2b\"",
      "\"456\",\"bar_value_2d\",\"var_value_2d\"",
      "def w: if type==\"array\" then . else [.] end;",
      ".data[]\n| .foo.item |= w\n| .bar.item |= w\n| .var.item |= w\n| range(0; .foo.item | length) as $i\n| select(.foo.item[$i].value != \"foo_bad\")\n| select(.bar.item[$i].value)\n| [.id,.bar.item[$i].value,.var.item[$i].value]\n| @csv"
    ],
    "utterance": "For each object in the input, output all combinations where the corresponding foo.item.value is not \"foo_bad\", reporting id, bar.item.value, and var.item.value.",
    "expressions": [
      "def w: if type==\"array\" then . else [.] end;\n.data[]\n| .foo.item |= w\n| .bar.item |= w\n| .var.item |= w\n| range(0; .foo.item | length) as $i\n| select(.foo.item[$i].value != \"foo_bad\")\n| select(.bar.item[$i].value)\n| [.id,.bar.item[$i].value,.var.item[$i].value]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "123",
              "foo": {
                "item": {
                  "value": "foo_good",
                  "bar_id": "1"
                }
              },
              "bar": {
                "item": {
                  "id": "1",
                  "value": "bar_value_1a"
                }
              },
              "var": {
                "item": {
                  "value": "var_value_1a",
                  "bar_id": "1"
                }
              }
            },
            {
              "id": "456",
              "foo": {
                "item": [
                  {
                    "value": "foo_bad",
                    "bar_id": "1"
                  },
                  {
                    "value": "foo_good",
                    "bar_id": "2"
                  },
                  {
                    "value": "foo_good",
                    "bar_id": "2"
                  },
                  {
                    "value": "foo_bad",
                    "bar_id": "3"
                  },
                  {
                    "value": "foo_good",
                    "bar_id": "4"
                  }
                ]
              },
              "bar": {
                "item": [
                  {
                    "id": "1",
                    "value": "bar_value_2a"
                  },
                  {
                    "id": "2",
                    "value": "bar_value_2b"
                  },
                  {
                    "id": "3",
                    "value": "bar_value_2c"
                  },
                  {
                    "id": "4",
                    "value": "bar_value_2d"
                  }
                ]
              },
              "var": {
                "item": [
                  {
                    "value": "var_value_2a",
                    "bar_id": "1"
                  },
                  {
                    "value": "var_value_2b",
                    "bar_id": "2"
                  },
                  {
                    "value": "var_value_2c",
                    "bar_id": "3"
                  },
                  {
                    "value": "var_value_2d",
                    "bar_id": "4"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "\"123\",\"bar_value_1a\",\"var_value_1a\"",
          "\"456\",\"bar_value_2b\",\"var_value_2b\"",
          "\"456\",\"bar_value_2d\",\"var_value_2d\""
        ]
      }
    ],
    "identifier": 53301111
  },
  {
    "context": [
      "I want to be able to do Vimdiffs and Vimfolds on Bookmarks files that have been converted to CVS files ie with one description and one uri per line.  However, because the Bookmarks file has multiple levels for the folders, the CSV file will also need fields for the different levels of folder names on each line.",
      "I am new to jq but it seems like it should be able to do this sort of conversion?",
      "When I need to reconstruct data I write a set of loops that identify each property I want for each line in my CSV. Let&#39;s say my JSON has `Name, Email, Phone` but for some reason all are at different object levels in my JSON.",
      "once you have a clean JSON with all data points at the same level CSV conversion is smooth."
    ],
    "utterance": "Convert a nested bookmarks file into lines with description, URI, and fields for each folder level as separate columns.",
    "expressions": [
      "def walkFolders(folders; path):\n  [\n    foreach folders[] as $item (null;\n      if $item.type == \"folder\" then\n        yield(walkFolders($item.children; path + [$item.name]))\n      elif $item.type == \"url\" then\n        [{ \"folders\": path, \"name\": $item.name, \"url\": $item.url }]\n      else\n        null\n      end)\n  ] | flatten;\nwalkFolders(.roots.bookmark_bar.children; [])\n| map([(.folders[]?), .name, .url])\n| (map(length) | max | range(0; .)) as $cols\n| map(map(tostring))\n| [ [ (\"folder_level_\" + (range(0; ($cols-2))) | tostring), \"name\", \"url\" ],\n    .[] ]\n| @csv"
    ],
    "identifier": 53299320
  },
  {
    "context": [
      "How do I filter this set to include all the fruits that are not red, or not round?",
      "How do I find all the fruit that are not red?",
      "I'm just looking for how to search for the records where the array does not contain a value.",
      "This should work:",
      "jq '.[] | select(.tags | index(\"red\") | not)' fruit.json"
    ],
    "utterance": "Find all fruit where the tags array does not contain the value \"red\".",
    "expressions": [
      ".[] | select(.tags | index(\"red\") | not)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "banana",
            "tags": [
              "yellow",
              "long"
            ]
          },
          {
            "name": "apple",
            "tags": [
              "red",
              "round"
            ]
          },
          {
            "name": "orange",
            "tags": [
              "orange",
              "round",
              "colored"
            ]
          }
        ],
        "output": [
          {
            "name": "banana",
            "tags": [
              "yellow",
              "long"
            ]
          },
          {
            "name": "orange",
            "tags": [
              "orange",
              "round",
              "colored"
            ]
          }
        ]
      }
    ],
    "identifier": 53512985
  },
  {
    "context": [
      "I'd like to know how to get the same effect with `jq`. I.e.",
      "$ jq .posts.<something>.message < jq_dat.json",
      "\"lorem ipsem\"",
      "\"dolor sit amet\"",
      "\"consectetur adipiscing elit\"",
      "I've tried using `[]` and `{}` in place of `something`, but those both spit back compile errors.",
      "You just have one too many dot",
      "jq .posts[].message < jq_dat.json"
    ],
    "utterance": "Extract all message values from every entry in the posts object.",
    "expressions": [
      ".posts[].message"
    ],
    "data": [
      {
        "input": {
          "order": [
            "hash1",
            "hash2"
          ],
          "posts": {
            "hash4": {
              "id": "hash4",
              "message": "lorem ipsem"
            },
            "hash5": {
              "id": "hash5",
              "message": "dolor sit amet"
            },
            "hash6": {
              "id": "hash6",
              "message": "consectetur adipiscing elit"
            }
          }
        },
        "output": [
          "lorem ipsem",
          "dolor sit amet",
          "consectetur adipiscing elit"
        ]
      }
    ],
    "identifier": 53396342
  },
  {
    "context": [
      "I would like just \r\n\r\n    HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6\r\n\r\nCurrently using my regex I get only if I use it without the JQ tool syntax \r\n\r\n    : ZA0Gas2GrHtdMlet1g63N6gvEPYf5mzZEfjPhMDRyAeS",
      "jq -r '.msg.stdout_lines[2]\n           | capture(\": (?<s>.*)\").s'",
      "jq -r '.msg.stdout_lines[2]|split(\" \")[-1]' file"
    ],
    "utterance": "Extract just the key value from the third element of the msg.stdout_lines array, where the line is of the form 'Unseal Key 3: ...'.",
    "expressions": [
      ".msg.stdout_lines[2] | capture(\": (?<s>.*)\").s",
      ".msg.stdout_lines[2] | split(\" \")[-1]"
    ],
    "data": [
      {
        "input": {
          "msg": {
            "stdout_lines": [
              "Unseal Key 1: ZA0Gas2GrHtdMlet1g63N6gvEPYf5mzZEfjPhMDRyAeS",
              "Unseal Key 2: NY+CLIbgMJIv+e81FuB1OpV0m7rPuqZbIuYT142MrQLl",
              "Unseal Key 3: HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6"
            ]
          }
        },
        "output": "HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6"
      }
    ],
    "identifier": 53544476
  },
  {
    "context": [
      "I'm using JQ to parse the output of aws commands to CSV.",
      "But the output is putting in extra quotes and slashes that aren't needed:",
      "Is there any way I can direct the @csv option to jq to leave out the quotes and backslashes? And just leave the commas.",
      "By default, jq emits JSON, so you will probably want to use the -r option:",
      "If you want to eliminate the quotation marks around strings which do not contain commas, then consider:",
      "map(t) | join(\"\\t\") | gsub(\"\\t\";\",\")"
    ],
    "utterance": "Produce a CSV-style output of specific fields so that the result contains only comma-separated values, without extra quotes or backslashes.",
    "expressions": [
      "jq -r '.Reservations[].Instances[] | [(.Tags[]|select(.Key==\"Name\")|.Value), .InstanceId, .PrivateIpAddress, .LaunchTime, .State.Name, (.Tags[]|select(.Key==\"Owner\")|.Value)] | @csv'",
      "jq -r '\n  def s: gsub(\"^\\\"|\\\"$\";\"\");\n  def t: if test(\",\") then . else s end;\n  map(t) | join(\"\\t\") | gsub(\"\\t\";\",\")'"
    ],
    "data": [
      {
        "input": [
          "usamzdbd2153",
          "i-7e0d8b91",
          "10.1.233.153",
          "2015-02-19T16:57:57.000Z",
          "running",
          "tsenti"
        ],
        "output": "usamzdbd2153,i-7e0d8b91,10.1.233.153,2015-02-19T16:57:57.000Z,running,tsenti"
      }
    ],
    "identifier": 53544042
  },
  {
    "context": [
      "Given the following json, which contains hierarchical data, i need to convert the following flat structure into a parent child json output format:",
      "How i could get an output like below, based on the path hierarchy?",
      "The key to the following solution is to convert the flat array into a hierarchical structure.  We use `setpath` to do this as follows:",
      "reduce .[] as $element ({};\n  setpath($element | .path | split(\"/\");\n          $element | {NameID, Name}))",
      "With your input, this produces the following:",
      "Now it's just a question of munging, which can be done using the following helper function:",
      "def promote:\n  . as $in\n  | (if .NameID then {(.NameID): .Name } else {} end) as $base\n  | del(.NameID) | del(.Name)\n  | if length == 0 then $base\n    else $base + {Children: (reduce keys_unsorted[] as $k ([]; . + [$in[$k] | promote] ))}\n    end;",
      "With this def, the solution becomes:",
      "reduce .[] as $element ({};\n  setpath($element | .path | split(\"/\");\n          $element | {NameID, Name}))\n| promote\n| .Children"
    ],
    "utterance": "Transform a flat array of objects with path-based hierarchy into a nested structure with parent-child relationships, where each node uses NameID as the key and Name as the value, and children are placed under the Children array.",
    "expressions": [
      "def promote:\n  . as $in\n  | (if .NameID then {(.NameID): .Name } else {} end) as $base\n  | del(.NameID) | del(.Name)\n  | if length == 0 then $base\n    else $base + {Children: (reduce keys_unsorted[] as $k ([]; . + [$in[$k] | promote] ))}\n    end;\n\nreduce .[] as $element ({};\n  setpath($element | .path | split(\"/\");\n          $element | {NameID, Name}))\n| promote\n| .Children"
    ],
    "data": [
      {
        "input": [
          {
            "ID": 1042,
            "NameID": "200",
            "Name": "related",
            "path": "1042"
          },
          {
            "ID": 1561,
            "NameID": "  230",
            "Name": "Patr",
            "FatherID": 1042,
            "path": "1042/1561"
          },
          {
            "ID": 1370,
            "NameID": "    230",
            "Name": "Dog",
            "FatherID": 1561,
            "path": "1042/1561/1370"
          },
          {
            "ID": 1560,
            "NameID": "    230.1",
            "Name": "Ort",
            "FatherID": 1561,
            "path": "1042/1561/1560"
          },
          {
            "ID": 213,
            "NameID": "    232",
            "Name": "Jim",
            "FatherID": 1561,
            "path": "1042/1561/213"
          }
        ],
        "output": [
          {
            "200": "related",
            "Children": [
              {
                "  230": "Patr",
                "Children": [
                  {
                    "    230": "Dog"
                  },
                  {
                    "    230.1": "Ort"
                  },
                  {
                    "    232": "Jim"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 53487500
  },
  {
    "context": [
      "How can I parse elements like id, name queue etc? I will iterate it in loop and work and build the insert query.",
      "$ jq -r '(.apps.app[0] | keys_unsorted) as $k\n    | $k, (.apps.app[] | [.[$k[]]])\n    | @csv\n' input.json"
    ],
    "utterance": "Extract all values for each app with their keys as CSV rows, including fields like id, name, and queue.",
    "expressions": [
      "(.apps.app[0] | keys_unsorted) as $k | $k, (.apps.app[] | [.[$k[]]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "apps": {
            "app": [
              {
                "id": "application_1540378900448_18838",
                "user": "hive",
                "name": "insert overwrite tabl...summary_view_stg_etl(Stage-2)",
                "queue": "Data_Ingestion",
                "state": "FINISHED",
                "finalStatus": "SUCCEEDED",
                "progress": 100
              },
              {
                "id": "application_1540378900448_18833",
                "user": "hive",
                "name": "insert into SNOW_WORK...metric_definitions')(Stage-13)",
                "queue": "Data_Ingestion",
                "state": "FINISHED",
                "finalStatus": "SUCCEEDED",
                "progress": 100
              }
            ]
          }
        }
      }
    ],
    "identifier": 53557983
  },
  {
    "context": [
      "For a specific usecase, I&#39;d like to add some data from a file into a feed that was pipe in stdout.",
      "cat /tmp/a1 | jq --argfile a2 /tmp/a2 '. + $a2'",
      "(cat /tmp/a1 ; cat /tmp/a2) | jq '. + input'",
      "jq -n --argfile a1 /tmp/a1 --argfile a2 /tmp/a2 '$a1 + $a2'",
      "<GENERATE a1> | cat - /tmp/a2 | jq --slurp '.[0] + .[1]'",
      "{ <GENERATE a1> ; cat /tmp/a2; } | jq --slurp '.[0] + .[1]'"
    ],
    "utterance": "Combine data piped from standard input with data from a file into a single array containing all objects.",
    "expressions": [
      "cat /tmp/a1 | jq --argfile a2 /tmp/a2 '. + $a2'",
      "(cat /tmp/a1 ; cat /tmp/a2) | jq '. + input'",
      "jq -n --argfile a1 /tmp/a1 --argfile a2 /tmp/a2 '$a1 + $a2'",
      "cat /tmp/a1 /tmp/a2 | jq --slurp '.[0] + .[1]'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": 1
            }
          ],
          [
            {
              "a": 2
            }
          ]
        ],
        "output": [
          {
            "a": 1
          },
          {
            "a": 2
          }
        ]
      }
    ],
    "identifier": 53533697
  },
  {
    "context": [
      "I want to return the keys of the ancestors of `Aliases` when `Aliases` contains a particular value.",
      "For example, given the search key `dos`, I want to return `node1` and `2`.",
      "(paths | select(.[-2] == \"Aliases\")) as $p\n| select( \"dos\" == getpath($p))\n| $p[:-2][]"
    ],
    "utterance": "Find the ancestor keys whose Aliases array contains the value 'dos', and return both the highest and next-highest keys leading to that value.",
    "expressions": [
      "(paths | select(.[-2] == \"Aliases\")) as $p | select( \"dos\" == getpath($p)) | $p[:-2][]"
    ],
    "data": [
      {
        "input": {
          "node1": {
            "1": {
              "Aliases": [
                "one",
                "uno"
              ]
            },
            "2": {
              "Aliases": [
                "two",
                "dos"
              ]
            }
          },
          "node2": {
            "a": {
              "Aliases": [
                "alpha"
              ]
            },
            "b": {
              "Aliases": [
                "bravo"
              ]
            }
          }
        },
        "output": [
          "node1",
          "2"
        ]
      }
    ],
    "identifier": 53561470
  },
  {
    "context": [
      "Would like to get output like:\r\n\r\n    [\r\n    \t{ \"key\": \"TEST-A\", \"inward\": null, \"outward\": null },\r\n    \t{ \"key\": \"TEST-B\", \"inward\": [\"TEST-1\"], \"outward\": [\"TEST-2\", \"TEST-3\"] }\r\n    ]",
      "def extract(f): map(f // empty) | if length ==0 then null else . end;\r\n    \r\n    .issues\r\n    | map(\r\n       {key,\r\n        inward: .fields.issuelinks|extract(.inwardIssue.key),\r\n        outward: .fields.issuelinks|extract(.outwardIssue.key)})"
    ],
    "utterance": "For each object, create a new object with its key, an array of all inwardIssue keys in 'inward' (or null if none), and an array of all outwardIssue keys in 'outward' (or null if none).",
    "expressions": [
      "def extract(f): map(f // empty) | if length ==0 then null else . end;\n\n.issues\n| map(\n   {key,\n    inward: .fields.issuelinks|extract(.inwardIssue.key),\n    outward: .fields.issuelinks|extract(.outwardIssue.key)})"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "TEST-A",
              "fields": {
                "issuelinks": []
              }
            },
            {
              "key": "TEST-B",
              "fields": {
                "issuelinks": [
                  {
                    "inwardIssue": {
                      "key": "TEST-1"
                    }
                  },
                  {
                    "outwardIssue": {
                      "key": "TEST-2"
                    }
                  },
                  {
                    "outwardIssue": {
                      "key": "TEST-3"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "key": "TEST-A",
            "inward": null,
            "outward": null
          },
          {
            "key": "TEST-B",
            "inward": [
              "TEST-1"
            ],
            "outward": [
              "TEST-2",
              "TEST-3"
            ]
          }
        ]
      }
    ],
    "identifier": 53416372
  },
  {
    "context": [
      "This is my json that i am trying to just jq to parse:",
      "{\"aaa-bbb-ccc\": { \"derp\": blah } }",
      "cat myjson | jq -r .'aaa-bbb-ccc'",
      "jq: error: aaa/0 is not defined at <top-level>, line 1:",
      ".aaa-bbb-ccc",
      "Using the basic form for accessing a key's value, you'd write:",
      "jq -r '.[\"KEYNAME\"]'",
      "In modern versions of jq, the basic form can be abbreviated to just .\"KEYNAME\".",
      "you could write (avoiding cat):",
      "jq -r '.\"aaa-bbb-ccc\"' myjson"
    ],
    "utterance": "Access the value of the top-level key named aaa-bbb-ccc containing hyphens.",
    "expressions": [
      ".[\"aaa-bbb-ccc\"]",
      ".\"aaa-bbb-ccc\""
    ],
    "data": [
      {
        "input": {
          "aaa-bbb-ccc": {
            "derp": "blah"
          }
        },
        "output": {
          "derp": "blah"
        }
      }
    ],
    "identifier": 53533323
  },
  {
    "context": [
      "I need to know all IP range (ip_prefix), associated with us-west-2 region only from this link - https://ip-ranges.amazonaws.com/ip-ranges.json",
      "jq -r '.prefixes[] | select(.region == \"us-west-2\") | .ip_prefix' input-file"
    ],
    "utterance": "List all ip_prefix values where region is us-west-2.",
    "expressions": [
      ".prefixes[] | select(.region == \"us-west-2\") | .ip_prefix",
      "jq -r '.prefixes[] | select(.region == \"us-west-2\") | .ip_prefix'"
    ],
    "identifier": 53566477
  },
  {
    "context": [
      "i want to transform the following input with jq",
      "don't know howto \"join\" the array  -> \"childarray\": [\"value1\", \"value2\"] to a comma delimited string -> \"value1, value2\"",
      "jq '.rows | map(.childarray |= join(\", \"))' input.json",
      "jq '.rows[].childarray |= join(\", \") | .rows'"
    ],
    "utterance": "Convert all 'childarray' arrays within each object in the 'rows' list into single strings with their elements joined by a comma and space.",
    "expressions": [
      ".rows | map(.childarray |= join(\", \"))",
      ".rows[].childarray |= join(\", \") | .rows"
    ],
    "data": [
      {
        "input": {
          "count": 1000,
          "rows": [
            {
              "id": 1,
              "child_id": 11,
              "childarray": [
                "value1",
                "value2"
              ]
            },
            {
              "id": 2,
              "child_id": 12,
              "childarray": [
                "value3",
                "value4"
              ]
            }
          ]
        },
        "output": [
          {
            "id": 1,
            "child_id": 11,
            "childarray": "value1, value2"
          },
          {
            "id": 2,
            "child_id": 12,
            "childarray": "value3, value4"
          }
        ]
      }
    ],
    "identifier": 53412455
  },
  {
    "context": [
      "I want to process this data ... into this ...",
      "this command ... errors out with 'Cannot iterate over null'",
      "How do you iterate over null and not skip array?",
      "jq '.results[] | {\n    headword,\n    definition: .senses[0].definition[0],\n    examples: (if .senses[0].examples then .senses[0].examples[0].text else null end)\n}' data.json",
      ".results[]\n| { headword }\n  + (.senses[]\n     | { definition: .definition[0],\n         examples: (if has(\"examples\")\n                    then [.examples[].text]\n                    else null end) } )"
    ],
    "utterance": "For each object, extract headword and the first definition, and set examples to the first example's text if present, otherwise null.",
    "expressions": [
      ".results[] | {headword, definition: .senses[0].definition[0], examples: (if .senses[0].examples then .senses[0].examples[0].text else null end)}"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "headword": "binding",
              "senses": [
                {
                  "definition": [
                    "a promise, agreement etc that must be obeyed"
                  ]
                }
              ]
            },
            {
              "headword": "non-binding",
              "senses": [
                {
                  "definition": [
                    "a non-binding agreement or decision does not have to be obeyed"
                  ],
                  "examples": [
                    {
                      "text": "The industry has signed a non-binding agreement to reduce pollution."
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "headword": "binding",
            "definition": "a promise, agreement etc that must be obeyed",
            "examples": null
          },
          {
            "headword": "non-binding",
            "definition": "a non-binding agreement or decision does not have to be obeyed",
            "examples": "The industry has signed a non-binding agreement to reduce pollution."
          }
        ]
      }
    ],
    "identifier": 53553689
  },
  {
    "context": [
      "Im trying to get values in with file extension \"**.tgz**\" with regular expression.",
      "jq -r ' .[] | to_entries | map(select(.key | test(\"*.tgz\")).value)'",
      "the string you want to test is accessible via .Key:",
      "jq -r ' .[] | select(.Key | test(\"\\\\.tgz$\")).Key'",
      "the argument of test must be the JSON representation of a regex."
    ],
    "utterance": "Select and output the values whose Key ends with the .tgz file extension.",
    "expressions": [
      ".[] | select(.Key | test(\"\\.tgz$\")) | .Key",
      ".[] | select(.Key | test(\"\\.tgz$\")) | .Key",
      ".[][] | select(test(\"\\.tgz$\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "raw/bene/test/nd_OneP4.tgz"
          },
          {
            "Key": "raw/bene/test/nd_OneP4.tgz"
          }
        ],
        "output": [
          "raw/bene/test/nd_OneP4.tgz",
          "raw/bene/test/nd_OneP4.tgz"
        ]
      }
    ],
    "identifier": 53496277
  },
  {
    "context": [
      "but now i want to get rid of the duplicate entries which have the same string in their search-attribute.",
      "the result , should be:\r\n\r\n      [\r\n      {\r\n        \"contraction\": \"TEST_1\",\r\n        \"definitions\": [\r\n          {\r\n            \"search\": \"1\",\r\n            \"replace\": \"12\"\r\n          },\r\n          {\r\n            \"search\": \"3\",\r\n            \"replace\": \"4\"\r\n          },\r\n          {\r\n            \"search\": \"6\",\r\n            \"replace\": \"2\"\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        \"contraction\": \"TEST_2\",\r\n        \"definitions\": [\r\n          {\r\n            \"search\": \"A\",\r\n            \"replace\": \"post\"\r\n          },\r\n          {\r\n            \"search\": \"B\",\r\n            \"replace\": \"prae\"\r\n          }\r\n        ]\r\n      }\r\n    ]",
      "You could simply extend your filter with this:\r\n\r\n    map( .definitions |= unique_by(.search) )"
    ],
    "utterance": "Remove duplicate entries in each object's definitions array where entries have the same search field, keeping the first occurrence.",
    "expressions": [
      "map(.definitions |= unique_by(.search))"
    ],
    "data": [
      {
        "input": [
          {
            "contraction": "TEST_1",
            "definitions": [
              {
                "search": "1",
                "replace": "12"
              },
              {
                "search": "3",
                "replace": "4"
              },
              {
                "search": "6",
                "replace": "2"
              },
              {
                "search": "1",
                "replace": "1"
              }
            ]
          },
          {
            "contraction": "TEST_2",
            "definitions": [
              {
                "search": "A",
                "replace": "post"
              },
              {
                "search": "B",
                "replace": "prae"
              },
              {
                "search": "A",
                "replace": ""
              }
            ]
          }
        ],
        "output": [
          {
            "contraction": "TEST_1",
            "definitions": [
              {
                "search": "1",
                "replace": "12"
              },
              {
                "search": "3",
                "replace": "4"
              },
              {
                "search": "6",
                "replace": "2"
              }
            ]
          },
          {
            "contraction": "TEST_2",
            "definitions": [
              {
                "search": "A",
                "replace": "post"
              },
              {
                "search": "B",
                "replace": "prae"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 53409951
  },
  {
    "context": [
      "However, if I add a query to include the name tags of the servers I get dramatically less number of server instances reported:",
      "aws ec2 describe-instances | jq -r '.Reservations[].Instances[] | [( (.Tags[]|select(.Key==\"Name\")|.Value), .InstanceId ) ]'",
      "For some reason that query reports that there are only 11 aws server instances (when there should be 47).",
      "Because your jq program is at variance with your expectations; specifically, you have overlooked what happens when .Tags evaluates to null.",
      "One solution\nIf you want `null` to appear whenever there isn't a tag:\n\n    .Reservations[].Instances[]\n    | [ ((.Tags // [])[] | select(.Key==\"Name\") | .Value) // null,\n        .InstanceId  ]",
      "Variant using `try`\n\n    .Reservations[].Instances[]\n    | [ try (.Tags[] | select(.Key==\"Name\")|.Value) // null,\n        .InstanceId  ]",
      "You would have to handle it or substitute an empty array in its place with `(.Tags // [])`.  But overall, I would write it like this:\n\n    .Reservations[].Instances[] | [ (.Tags // [] | from_entries.Name), .InstanceId ]"
    ],
    "utterance": "List all server instance IDs with their Name tag value or null if the tag is missing; include every instance regardless of whether it has tags.",
    "expressions": [
      ".Reservations[].Instances[] | [ ((.Tags // [])[] | select(.Key==\"Name\") | .Value) // null, .InstanceId ]",
      ".Reservations[].Instances[] | [ try (.Tags[] | select(.Key==\"Name\")|.Value) // null, .InstanceId ]",
      ".Reservations[].Instances[] | [ (.Tags // [] | from_entries.Name), .InstanceId ]"
    ],
    "identifier": 53563511
  },
  {
    "context": [
      "OK. I want to display **InstanceId** json as follows:",
      "{\n\t\"Tags\": {\n\t\t\"Name\": \"4d2\",\n\t\t\"c\": \"c\",\n\t\t\"a\": \"a\",\n\t\t\"b\": \"b\"\n\t},\n\t\"VolumeId\": \"vol-0be41aaca50a1d4d2\",\n\t\"SnapshotId\": \"snap-0be43cb27ae60c978\",\n\t\"Volumesize\": 8,\n\t\"CreateTime\": \"2018-09-20T02:24:21.067Z\",\n\t\"State\": \"in-use\",\n\t\"Instances\": [{\n\t\t\"InstanceId\": \"i-016c1d0448d6917f6\"\n\t}]\n}",
      "You can use this jq filter:",
      "jq '.+{\"Instances\":[{InstanceId}]}|del(.InstanceId)' file"
    ],
    "utterance": "Reformat the object so that InstanceId is nested inside an Instances array as an object, removing the original InstanceId field at the root.",
    "expressions": [
      ".+{\"Instances\":[{InstanceId}]}|del(.InstanceId)"
    ],
    "data": [
      {
        "input": {
          "Tags": {
            "Name": "4d2",
            "c": "c",
            "a": "a",
            "b": "b"
          },
          "VolumeId": "vol-0be41aaca50a1d4d2",
          "SnapshotId": "snap-0be43cb27ae60c978",
          "Volumesize": 8,
          "CreateTime": "2018-09-20T02:24:21.067Z",
          "State": "in-use",
          "InstanceId": "i-016c1d0448d6917f6"
        },
        "output": {
          "Tags": {
            "Name": "4d2",
            "c": "c",
            "a": "a",
            "b": "b"
          },
          "VolumeId": "vol-0be41aaca50a1d4d2",
          "SnapshotId": "snap-0be43cb27ae60c978",
          "Volumesize": 8,
          "CreateTime": "2018-09-20T02:24:21.067Z",
          "State": "in-use",
          "Instances": [
            {
              "InstanceId": "i-016c1d0448d6917f6"
            }
          ]
        }
      }
    ],
    "identifier": 53257328
  },
  {
    "context": [
      "Now I want to retrieve `electronicText` value.",
      "So I want to retrieve `electronicText`  key  without using indexes.",
      "I want to use `stream` option for large JSON file.",
      "jq --stream 'select(.[0]|contains([\"electronicText\"]))|.[1]//empty'",
      "jq --stream '\n  select(length==2 and .[0][-1]==\"electronicText\")|.[1]\n' input.json\n\"15570075\""
    ],
    "utterance": "Extract the electronicText value from the data without using array indexes, using the stream option.",
    "expressions": [
      "jq --stream 'select(.[0]|contains([\"electronicText\"]))|.[1]//empty'",
      "jq --stream 'select(length==2 and .[0][-1]==\"electronicText\")|.[1]'"
    ],
    "data": [
      {
        "input": {
          "A": [
            {
              "B": {
                "C": [
                  {
                    "D": {
                      "applicationNumberText": {
                        "value": "15570075",
                        "electronicText": "15570075"
                      },
                      "date": "2018-10-01",
                      "app": "Utility"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": "15570075"
      }
    ],
    "identifier": 53256388
  },
  {
    "context": [
      "How can `jq` extract both the `index` key and `doctype` key based on the `dynamic` attribute?",
      "to give:\r\n\r\n    {\r\n        \"index1\": {\r\n            \"doctype2\": { \"dynamic\": \"static\" }\r\n        },\r\n        {\r\n        \"index2\": {\r\n            \"doctype3\": { \"dynamic\": \"static\" }\r\n        }\r\n    }",
      "For the first output:\r\n\r\n    jq '[\r\n          tostream|\r\n          select(.[1]==\"static\" and (.[0]|.[-1] == \"dynamic\"))|\r\n          {(.[0]|.[0]):{(.[0]|.[2]):{(.[0]|.[3]):.[1]}}}\r\n        ]|add'",
      "To obtain the output in the first form:\r\n    map_values( .mappings\r\n                | with_entries( select( .value.dynamic == \"static\" )) )"
    ],
    "utterance": "Select all top-level keys whose mappings contain a doctype with dynamic equal to \"static\", and output only those doctypes and their dynamic values.",
    "expressions": [
      "[\n  tostream |\n  select(.[1] == \"static\" and (.[0]|.[-1] == \"dynamic\")) |\n  {(.[0]|.[0]):{(.[0]|.[2]):{(.[0]|.[3]):.[1]}}}\n]|add",
      "map_values(.mappings | with_entries(select(.value.dynamic == \"static\")))"
    ],
    "data": [
      {
        "input": {
          "index1": {
            "mappings": {
              "doctype1": {
                "dynamic": "true"
              },
              "doctype2": {
                "dynamic": "static"
              }
            }
          },
          "index2": {
            "mappings": {
              "doctype3": {
                "dynamic": "static"
              },
              "doctype4": {
                "dynamic": "true"
              }
            }
          }
        },
        "output": {
          "index1": {
            "doctype2": {
              "dynamic": "static"
            }
          },
          "index2": {
            "doctype3": {
              "dynamic": "static"
            }
          }
        }
      }
    ],
    "identifier": 53280221
  },
  {
    "context": [
      "i have data which look like the following\nand i need to transform them.",
      "How could i get the following format as output?",
      "where each key us the number of the event, and in the array, we have the unique values of each event's org.",
      "output \n13: [\"AB KIO\",\"T\u0399 UIH\"]\n17: [\"GH SVS\"]",
      "map( {rc: (.rc|.[\"$event\"]), org} )\n| aggregate_by(.rc; .org)\n| map_values(unique)",
      "With your sample input modified to make it a JSON array, the above jq program produces:\n\n{\"13\":[\"AB KIO\",\"T\u0399 UIH\"],\"17\":[\"GH SVS\"]}"
    ],
    "utterance": "Group objects by the rc.$event value, and for each event, output the unique org values as an array under a key named after the event.",
    "expressions": [
      "def aggregate_by(f; g): reduce .[] as $x  ({}; .[$x|f] += [$x|g]); map( {rc: (.rc[\"$event\"]), org} ) | aggregate_by(.rc; .org) | map_values(unique)"
    ],
    "data": [
      {
        "input": [
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d2"
            },
            "org": "T\u0399 UIH",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d3"
            },
            "org": "T\u0399 UIH",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d4"
            },
            "org": "AB KIO",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d5"
            },
            "org": "GH SVS",
            "rc": {
              "$event": "17"
            }
          }
        ],
        "output": {
          "13": [
            "AB KIO",
            "T\u0399 UIH"
          ],
          "17": [
            "GH SVS"
          ]
        }
      }
    ],
    "identifier": 53504045
  },
  {
    "context": [
      "as you see object in json file don't have the same attributes so i'm looking only on object has \"name \" attribute,the following script  reads the Json file and return the values of **attribute name only** ,but i build something wrond as theERROR always on the \"{\" of the last object in file I don't know why , what i am i doing wrong?",
      "the expected output is : [myna, mry]",
      "The input of `jq` is a list, which doesn't have *any* keys, let alone one named `name`. You want\n\n    jq -r '.[].name'\n\ninstead."
    ],
    "utterance": "Extract all values of the name attribute from an array of objects, and output the list of names.",
    "expressions": [
      ".[].name"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "myna",
            "description": "Simple Question",
            "speaker": "USER"
          },
          {
            "all_Id's": [
              "11111"
            ],
            "user": "me"
          },
          {
            "id": 2,
            "name": "mry",
            "description": "Simple",
            "speaker": "aaa"
          }
        ],
        "output": [
          "myna",
          "mry"
        ]
      }
    ],
    "identifier": 53252798
  },
  {
    "context": [
      "How do I use jq to clean the results so it only retains the history array entries for each element? The desired output is something like this (output-20181118123808.json for analysis done on \"2018-11-18T12:37:08+0000\"): ...",
      "is there a variation wherein the filtering is based on the date value and not the position? It is not guaranteed that the order will be the same or the number of elements in each metric is going to be the same (i.e. some dates may be missing \"bugs\", some might have additional metric such as \"complexity\").",
      "def dates:\n  INDEX(.measures[].history[].date; .)\n  | keys;\n\ndef gather($date): map(select(.date==$date));\n\ndates[] as $date\n| .measures |= map( .history |= gather($date) )"
    ],
    "utterance": "For each unique date found in any measure's history, produce the top-level structure with only the history entries from all measures that match that date.",
    "expressions": [
      "def dates:\n  INDEX(.measures[].history[].date; .)\n  | keys;\n\ndef gather($date): map(select(.date==$date));\n\ndates[] as $date\n| .measures |= map( .history |= gather($date) )"
    ],
    "data": [
      {
        "input": {
          "paging": {
            "pageIndex": 1,
            "pageSize": 100,
            "total": 3
          },
          "measures": [
            {
              "metric": "coverage",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "100.0"
                },
                {
                  "date": "2018-11-21T12:22:39+0000",
                  "value": "100.0"
                },
                {
                  "date": "2018-11-21T13:09:02+0000",
                  "value": "100.0"
                }
              ]
            },
            {
              "metric": "bugs",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "0"
                },
                {
                  "date": "2018-11-21T12:22:39+0000",
                  "value": "0"
                },
                {
                  "date": "2018-11-21T13:09:02+0000",
                  "value": "0"
                }
              ]
            },
            {
              "metric": "vulnerabilities",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "0"
                },
                {
                  "date": "2018-11-21T12:22:39+0000",
                  "value": "0"
                },
                {
                  "date": "2018-11-21T13:09:02+0000",
                  "value": "0"
                }
              ]
            }
          ]
        },
        "output": {
          "paging": {
            "pageIndex": 1,
            "pageSize": 100,
            "total": 3
          },
          "measures": [
            {
              "metric": "coverage",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "100.0"
                }
              ]
            },
            {
              "metric": "bugs",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "0"
                }
              ]
            },
            {
              "metric": "vulnerabilities",
              "history": [
                {
                  "date": "2018-11-18T12:37:08+0000",
                  "value": "0"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 53491351
  },
  {
    "context": [
      "\"I want to simply increment the buildNumber by one in the file. Rest of the content should remain as is.\"",
      "\"the filter to use is:\n\n    .buildNumber += 1\"",
      "\"jq '.buildNumber += 1' 'package.json' > 'package.json.tmp'\""
    ],
    "utterance": "Increment the field buildNumber by one, preserving all other fields and structure.",
    "expressions": [
      ".buildNumber += 1"
    ],
    "data": [
      {
        "input": {
          "version": "2.1.0",
          "buildNumber": 83
        },
        "output": {
          "version": "2.1.0",
          "buildNumber": 84
        }
      }
    ],
    "identifier": 53406879
  },
  {
    "context": [
      "Given input of the form \r\n\r\n    [\r\n        {\"a\": 1, \"b\": [{\"c\": 1}, {\"c\": 2}]}, \r\n        {\"a\": 2, \"b\": [{\"c\": 4}, {\"c\": 5}]}\r\n    ]\r\n\r\nI'm trying to transform to look like:\r\n\r\n    [\r\n        {\"a\": 1, \"b\": [{\"c\": 1}],\r\n        {\"a\": 1, \"b\": [{\"c\": 2}],\r\n        {\"a\": 2, \"b\": [{\"c\": 3}],\r\n        {\"a\": 2, \"b\": [{\"c\": 4}]\r\n    ]",
      "You can try this filter:\r\n\r\n    jq 'map({a,\"b\":.b[]|[.]})' file",
      "Here's a straightforward solution that makes no mention of any keys besides \"b\":\r\n\r\n    map(. + (.b[] | {b: [.]}))"
    ],
    "utterance": "For each object, output a new object for each element in 'b', where 'b' contains only that single element, preserving other keys.",
    "expressions": [
      "map({a, \"b\": .b[] | [.]})",
      "map(. + (.b[] | {b: [.]}))"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": [
              {
                "c": 1
              },
              {
                "c": 2
              }
            ]
          },
          {
            "a": 2,
            "b": [
              {
                "c": 4
              },
              {
                "c": 5
              }
            ]
          }
        ],
        "output": [
          {
            "a": 1,
            "b": [
              {
                "c": 1
              }
            ]
          },
          {
            "a": 1,
            "b": [
              {
                "c": 2
              }
            ]
          },
          {
            "a": 2,
            "b": [
              {
                "c": 4
              }
            ]
          },
          {
            "a": 2,
            "b": [
              {
                "c": 5
              }
            ]
          }
        ]
      }
    ],
    "identifier": 53286133
  },
  {
    "context": [
      "jq is telling you that your jq query is not always valid.  So one option would be to make your jq query more robust, e.g. by using postfix `?` (e.g. `.Effect?`), or testing the type of the input, etc.",
      "Putting the `2> /dev/null` to the end of the jq command works."
    ],
    "utterance": "Return all Effect fields from Statement in PolicyVersion.Document, but suppress all error messages.",
    "expressions": [
      ".PolicyVersion.Document.Statement[].Effect?",
      ".PolicyVersion.Document.Statement.Effect?",
      "jq -r '.PolicyVersion.Document.Statement[].Effect' 2>/dev/null",
      "jq -r '.PolicyVersion.Document.Statement.Effect' 2>/dev/null"
    ],
    "identifier": 53233221
  },
  {
    "context": [
      "Need to extent to include \"acct\" and a literal value of \"acct1\" into the resulting json.",
      "Is there a way to do it inline with one line of code - like this which is not working ?",
      "jq '.[]|{acct:\"acct1\",name:.name,type:.type}' r.json",
      "A more economical approach to achieving what I understand you want would be:",
      "jq '.[]|{name,type, acct:\"acct1\"}' r.json"
    ],
    "utterance": "Output each item with its name, type, and an acct field set to the literal value acct1.",
    "expressions": [
      ".[] | {name, type, acct: \"acct1\"}"
    ],
    "identifier": 53462496
  },
  {
    "context": [
      "I have a dictionary which looks like:",
      "Then, I have an array which is:",
      "Expected output:\r\n\r\n    value01 value02 value03",
      "I have some trouble to make jq using an array which is not json format.",
      "Here\r\n\r\n    jq -r --arg array \"$array\" \\\r\n      'from_entries | .[($array | split(\" \"))[]]' \\\r\n      dictionary.json\r\n\r\nOutput\r\n\r\n    value01\r\n    value02\r\n    value03",
      "Using `INDEX/2`, which constructs a dictionary:\r\n\r\n    echo 'key01 key02 key03' |\r\n      jq -Rr --argfile dict dictionary.json '\r\n        INDEX($dict[]; .key) as $d\r\n        | split(\" \") | map( $d[.]|.value )\r\n        | join(\" \")'\r\n\r\nyields:\r\n\r\n    value01 value02 value03"
    ],
    "utterance": "For each element in the space-separated list 'key01 key02 key03', output the corresponding 'value' from the dictionary using the order given in the input.",
    "expressions": [
      "jq -r --arg array \"$array\" 'from_entries | .[($array | split(\" \"))[]]' dictionary.json",
      "jq -Rr --argfile dict dictionary.json 'INDEX($dict[]; .key) as $d | split(\" \") | map( $d[.]|.value ) | join(\" \")'"
    ],
    "data": [
      {
        "input": [
          {
            "key": "key01",
            "value": "value01"
          },
          {
            "key": "key02",
            "value": "value02"
          },
          {
            "key": "key03",
            "value": "value03",
            "extraProperty": {
              "foo": "bar"
            }
          },
          {
            "key": "key04",
            "value": "value04"
          }
        ],
        "output": [
          "value01",
          "value02",
          "value03"
        ]
      }
    ],
    "identifier": 53242090
  },
  {
    "context": [
      "I want to parse the JSON '{\"status\":\"running\",\"details\":\"0\"}' and assign 'running' and 'details' to two different variables where I can print status and details both.",
      "Instead of parsing the JSON twice, I want to do it only once. Hence I want to combine the following lines but still assign the status and details to two separate variables -",
      "You can use a construction like:\n\n    read status1 details1 < <(jq -r '.status + \" \" + .details' <<< \"${response}\")",
      "jq -r '.status + \"\\u0000\" + .details + \"\\u0000\"' <<<\"$response\"",
      "curl \"whatever\" | jq -r '[.status, .details] |@tsv'",
      "curl \"whatever\" | jq -r '[.status, .details] |join(\"\\t\")'"
    ],
    "utterance": "Extract the values of 'status' and 'details' fields at the top level, outputting them on the same line separated by a space, tab, or NUL.",
    "expressions": [
      ".status + \" \" + .details",
      ".status + \"\\u0000\" + .details + \"\\u0000\"",
      "[.status, .details] | @tsv",
      "[.status, .details] | join(\"\\t\")"
    ],
    "data": [
      {
        "input": {
          "status": "running",
          "details": "0"
        },
        "output": "running 0"
      }
    ],
    "identifier": 53508885
  },
  {
    "context": [
      "Is there a way to perform this sort of merge, replacing values on matching keys and preserving order?",
      "But (imagine 60 params) it's not easily scanned as correct, and what I want is this:",
      "The easy thing to do is to build a map from the keys to the values (combining all the input sources in turn), and then go back and reprocess `default.json`, applying that generated map.",
      "jq -n --slurpfile template default.json '\n# generate an unordered key:value dictionary\n([inputs | .[] | {(.ParameterKey): (.ParameterValue)}] | add) as $map |\n# apply those pairs to the template to get its ordering\n[ $template[0][] | {\"ParameterKey\": (.ParameterKey), \"ParameterValue\": ($map[.ParameterKey])} ]\n' default.json environment.json user.json secure.json",
      "`unique_by` entails a sort, so the simplest would be to use `INDEX` (uppercase):\n\n    [INDEX(inputs[]; .ParameterKey)[]]"
    ],
    "utterance": "Merge multiple configuration arrays from several files, replacing values on matching keys and preserving the order of keys from the template file.",
    "expressions": [
      "jq -n --slurpfile template default.json '([inputs | .[] | {(.ParameterKey): (.ParameterValue)}] | add) as $map | [ $template[0][] | {\"ParameterKey\": (.ParameterKey), \"ParameterValue\": ($map[.ParameterKey])} ]' default.json environment.json user.json secure.json",
      "[INDEX(inputs[]; .ParameterKey)[]]"
    ],
    "data": [
      {
        "input": {
          "default.json": [
            {
              "ParameterKey": "FirstStackName",
              "ParameterValue": "Production-App-Database"
            },
            {
              "ParameterKey": "SecondStackName",
              "ParameterValue": "Production-Directory"
            },
            {
              "ParameterKey": "ThirdStackName",
              "ParameterValue": "Production-VPC"
            },
            {
              "ParameterKey": "FourthStackName",
              "ParameterValue": "AMIFunctions"
            },
            {
              "ParameterKey": "FifthKeyName",
              "ParameterValue": "administrator"
            },
            {
              "ParameterKey": "SixthUserName",
              "ParameterValue": "admin"
            },
            {
              "ParameterKey": "SeventhPassword",
              "ParameterValue": ""
            }
          ],
          "environment.json": [
            {
              "ParameterKey": "FirstStackName",
              "ParameterValue": "Development-App-Database"
            },
            {
              "ParameterKey": "SecondStackName",
              "ParameterValue": "Development-Directory"
            },
            {
              "ParameterKey": "ThirdStackName",
              "ParameterValue": "Development-VPC"
            },
            {
              "ParameterKey": "FifthKeyName",
              "ParameterValue": "developer"
            }
          ],
          "user.json": [
            {
              "ParameterKey": "FifthKeyName",
              "ParameterValue": "jdoe"
            }
          ],
          "secure.json": [
            {
              "ParameterKey": "SeventhPassword",
              "ParameterValue": "secretvalue"
            }
          ]
        },
        "output": [
          {
            "ParameterKey": "FirstStackName",
            "ParameterValue": "Development-App-Database"
          },
          {
            "ParameterKey": "SecondStackName",
            "ParameterValue": "Development-Directory"
          },
          {
            "ParameterKey": "ThirdStackName",
            "ParameterValue": "Development-VPC"
          },
          {
            "ParameterKey": "FourthStackName",
            "ParameterValue": "AMIFunctions"
          },
          {
            "ParameterKey": "FifthKeyName",
            "ParameterValue": "jdoe"
          },
          {
            "ParameterKey": "SixthUserName",
            "ParameterValue": "admin"
          },
          {
            "ParameterKey": "SeventhPassword",
            "ParameterValue": "secretvalue"
          }
        ]
      }
    ],
    "identifier": 53567043
  },
  {
    "context": [
      "I need to list down the values of all  '.url' no matter how deeply it is nested.",
      "The expected output is as follows:\n\n    [\"abc/efg/dgh.com\", \"efef/dedede/efdgh.com\"]",
      "If you need to access something \"no matter how deeply it is nested\", then `recurse` is your friend.",
      "jq '[recurse|.url? // empty]' file.json"
    ],
    "utterance": "List all values of fields named 'url' at any nesting depth within the data.",
    "expressions": [
      "[recurse|.url? // empty]"
    ],
    "data": [
      {
        "input": {
          "section1": {
            "url": "abc/efg/dgh.com",
            "name": "test1"
          },
          "section2": {
            ".section3": {
              "url": "efef/dedede/efdgh.com",
              "name": "test2"
            }
          }
        },
        "output": [
          "abc/efg/dgh.com",
          "efef/dedede/efdgh.com"
        ]
      }
    ],
    "identifier": 53591656
  },
  {
    "context": [
      "First, I need to concatenate .status with .value by string (sorry for my poor json knowledge) --> \"status\":{\"57\": \"b\"} with \"value\":{\"57\": 57.1}.",
      ".value as $dict\n| .status\n| to_entries\n| map( [.key, .value, $dict[.key]] )\n| .[]\n| @csv",
      "With your input, and invoking jq with the -r option, this produces:\n\n    \"57\",\"b\",57.1"
    ],
    "utterance": "Concatenate the entries of the object at .status with the corresponding entries in .value, matching by key, and output each as a CSV row.",
    "expressions": [
      ".value as $dict | .status | to_entries | map([.key, .value, $dict[.key]]) | .[] | @csv"
    ],
    "data": [
      {
        "input": {
          "status": {
            "57": "b"
          },
          "value": {
            "57": 57.1
          }
        },
        "output": "\"57\",\"b\",57.1"
      }
    ],
    "identifier": 53505949
  },
  {
    "context": [
      "I want to combine all these into a single JSON object to hand over to another system for more fun.",
      "If the stream of objects is already in a file, use `inputs` with the -n command-line option.",
      "jq -n 'reduce inputs as $in ({}; . + $in)'"
    ],
    "utterance": "Combine a sequence of objects, each with a single date key, into one object mapping all dates to their values.",
    "expressions": [
      "reduce .[] as $in ({}; . + $in)",
      "jq -n 'reduce inputs as $in ({}; . + $in)'"
    ],
    "data": [
      {
        "input": [
          {
            "2018-10-09T19:00:00.000Z": []
          },
          {
            "2018-10-09T20:00:00.000Z": []
          },
          {
            "2018-10-09T21:00:00.000Z": []
          }
        ],
        "output": {
          "2018-10-09T19:00:00.000Z": [],
          "2018-10-09T20:00:00.000Z": [],
          "2018-10-09T21:00:00.000Z": []
        }
      }
    ],
    "identifier": 53420766
  },
  {
    "context": [
      "How can I return the merged arrays in this object. The expected output would be:",
      "[.[]] | add",
      "[.[][]]"
    ],
    "utterance": "Return a single concatenated array containing all elements from each array value in an object with arbitrary keys.",
    "expressions": [
      "[.[]] | add",
      "[.[][]]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            "hello",
            "world"
          ],
          "bar": [
            "foobar"
          ]
        },
        "output": [
          "hello",
          "world",
          "foobar"
        ]
      }
    ],
    "identifier": 53602197
  },
  {
    "context": [
      "The command that I'm using is the next one: \n\n    n_rules=$(echo rulebase_list | jq '.total')",
      "There is no \"total\" : 126 in the string you pass to jq because you pass it the output of echo rulebase_list that is rulebase_list.",
      "What you probably wanted is to send to jq the content of the rulebase_list file and the tool for this is cat:\n\n    n_rules=$(cat rulebase_list | jq '.total')",
      "Alternatively (and faster) is to redirect the input of jq from the file:\n\n    n_rules=$(jq '.total' < rulebase_list)",
      "Or to specify the input file name as the last argument in the command line of jq:\n\n    n_rules=$(jq '.total' rulebase_list)"
    ],
    "utterance": "Extract the value of the 'total' key from the file rulebase_list which contains top-level data.",
    "expressions": [
      "jq '.total' rulebase_list",
      "jq '.total' < rulebase_list",
      "cat rulebase_list | jq '.total'"
    ],
    "data": [
      {
        "input": {
          "total": 126
        },
        "output": 126
      }
    ],
    "identifier": 53280090
  },
  {
    "context": [
      "I am trying to replace project ParameterKey:Project with ParameterValue:test in the below Cloudformation parameters file",
      "map(if .ParameterKey == \"Project\"\n              then . + {\\\"ParameterValue\\\":\\\"test\\\"}\n              else .\n              end)",
      "You can simplify by enclosing the expression with single quotes, and no escaping is necessary:",
      "$ cat config.json | jq 'map(if .ParameterKey == \"Project\" then . + {\"ParameterValue\":\"test\"} else . end)'"
    ],
    "utterance": "Replace the value associated with ParameterKey equal to Project so that ParameterValue becomes test.",
    "expressions": [
      "map(if .ParameterKey == \"Project\" then . + {\"ParameterValue\":\"test\"} else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "Project",
            "ParameterValue": "<changeMe>"
          },
          {
            "ParameterKey": "DockerInstanceType",
            "ParameterValue": "m3.medium"
          }
        ],
        "output": [
          {
            "ParameterKey": "Project",
            "ParameterValue": "test"
          },
          {
            "ParameterKey": "DockerInstanceType",
            "ParameterValue": "m3.medium"
          }
        ]
      }
    ],
    "identifier": 53510540
  },
  {
    "context": [
      "I want to transform the following input with jq:",
      "but I don't know how to join the array property `\"prop1\"` to a comma-delimited string `\"prop1_value3,prop1_value4\"`.",
      "You need to map the objects contained in the `field3Array` to their string values and join the resulting array :",
      ".root | map({field1, field2, field3Array: .field3Array | map(.prop1) | join(\",\")})",
      ".root | map(.field3Array |= (map(.prop1) | join(\",\")))",
      "[.root[] | {field1, field2, field3Array: [ .field3Array[] | .prop1 ] | join(\",\")}]"
    ],
    "utterance": "Convert each object's field3Array from an array of objects with prop1 to a single comma-delimited string of prop1 values, preserving field1 and field2.",
    "expressions": [
      ".root | map({field1, field2, field3Array: .field3Array | map(.prop1) | join(\",\")})",
      ".root | map(.field3Array |= (map(.prop1) | join(\",\")))",
      "[.root[] | {field1, field2, field3Array: [ .field3Array[] | .prop1 ] | join(\",\")}]"
    ],
    "data": [
      {
        "input": {
          "root": [
            {
              "field1": "field1value1",
              "field2": "field2value2",
              "field3Array": [
                {
                  "prop1": "prop1_value1"
                }
              ]
            },
            {
              "field1": "field1value3",
              "field2": "field2value4",
              "field3Array": [
                {
                  "prop1": "prop1_value3"
                },
                {
                  "prop1": "prop1_value4"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "field1": "field1value1",
            "field2": "field2value2",
            "field3Array": "prop1_value1"
          },
          {
            "field1": "field1value3",
            "field2": "field2value4",
            "field3Array": "prop1_value3,prop1_value4"
          }
        ]
      }
    ],
    "identifier": 53594410
  },
  {
    "context": [
      "I wanna merge objects in tmp1.json and tmp2.json with InstanceId unique value in bash shell.",
      "My desired is:\r\n\r\n    {\r\n          \"VolumeId\": \"vol-046e0be08ac95095a\",\r\n          \"Instances\": [\r\n            {\r\n              \"InstanceId\": \"i-020ce1b2ad08fa6bd\"\r\n              \"InstanceName\": \"Test\"\r\n            }\r\n          ]\r\n        }\r\n        {\r\n          \"VolumeId\": \"vol-007253a7d24c1c668\",\r\n          \"Instances\": [\r\n            {\r\n              \"InstanceId\": \"i-0c0650c15b099b993\"\r\n              \"InstanceName\": \"Test1\"\r\n            }\r\n          ]\r\n        }",
      "One way to get around the constraints of using jq 1.4 is to use the \"slurp\" option so that the contents of the two files can be kept separately.",
      "INDEX(.[1][]; .InstanceId) as $dict\n| .[0][]\n| .Instances |= map(.InstanceName = $dict[.InstanceId].InstanceName)",
      "cat tmp2.json|jq -r '\"\\(.InstanceId) \\(.InstanceName)\"'|xargs -n2 sh -c 'cat tmp1.json|jq \"if .Instances[0].InstanceId==\\\"$0\\\" then .Instances[0].InstanceName=\\\"$1\\\" else empty end\"'"
    ],
    "utterance": "Merge objects from two files by appending InstanceName from one file onto the matching InstanceId in Instances of another file, producing combined objects with both InstanceId and InstanceName.",
    "expressions": [
      "jq -s 'INDEX(.[1][]; .InstanceId) as $dict | .[0][] | .Instances |= map(.InstanceName = $dict[.InstanceId].InstanceName)' tmp1.json tmp2.json",
      "cat tmp2.json | jq -r '\"\\(.InstanceId) \\(.InstanceName)\"' | xargs -n2 sh -c 'cat tmp1.json | jq \"if .Instances[0].InstanceId==\\\"$0\\\" then .Instances[0].InstanceName=\\\"$1\\\" else empty end\"'"
    ],
    "data": [
      {
        "input": [
          {
            "VolumeId": "vol-046e0be08ac95095a",
            "Instances": [
              {
                "InstanceId": "i-020ce1b2ad08fa6bd"
              }
            ]
          },
          {
            "VolumeId": "vol-007253a7d24c1c668",
            "Instances": [
              {
                "InstanceId": "i-0c0650c15b099b993"
              }
            ]
          }
        ],
        "output": [
          {
            "VolumeId": "vol-046e0be08ac95095a",
            "Instances": [
              {
                "InstanceId": "i-020ce1b2ad08fa6bd",
                "InstanceName": "Test"
              }
            ]
          },
          {
            "VolumeId": "vol-007253a7d24c1c668",
            "Instances": [
              {
                "InstanceId": "i-0c0650c15b099b993",
                "InstanceName": "Test1"
              }
            ]
          }
        ]
      },
      {
        "input": [
          {
            "InstanceId": "i-0c0650c15b099b993",
            "InstanceName": "Test1"
          },
          {
            "InstanceId": "i-020ce1b2ad08fa6bd",
            "InstanceName": "Test"
          }
        ]
      }
    ],
    "identifier": 53738501
  },
  {
    "context": [
      "Now I'd like to iterate over each key, listing the top-level field names only",
      "show me all the field-names only for key x.",
      "jq -r '. as $in | keys[] | . as $serverName | $in[$serverName] | keys | join(\",\") | \"\\($serverName) : \\(.)\"' pipeline/components/devsvr.json",
      "jq -r '.[] | keys_unsorted[]' devsvr.json",
      "keys[] as $serverName | .[$serverName] | \"\\($serverName) : \\(keys|join(\",\"))\""
    ],
    "utterance": "List the top-level field names for each first-level key, displaying both the key and its corresponding field names.",
    "expressions": [
      "jq -r '. as $in | keys[] | . as $serverName | $in[$serverName] | keys | join(\",\") | \"\\($serverName) : \\(.)\"' pipeline/components/devsvr.json",
      "jq -r '.[] | keys_unsorted[]' devsvr.json",
      "jq -r 'keys[] as $serverName | .[$serverName] | \"\\($serverName) : \\(keys|join(\",\"))\"' devsvr.json"
    ],
    "data": [
      {
        "input": {
          "server1": {
            "type": "single-instance",
            "stage": "10default",
            "descriptor": {
              "Resources": {
                "Instance": {
                  "Properties": {
                    "InstanceType": "t2.medium",
                    "ImageId": {}
                  }
                },
                "Metadata": {
                  "AWS::CloudFormation::Init": {
                    "app": {
                      "packages": {
                        "yum": {
                          "tmux": [],
                          "vim": []
                        }
                      },
                      "files": {
                        "sources": {},
                        "commands": {},
                        "services": {}
                      }
                    }
                  }
                }
              }
            }
          },
          "server2": {
            "type": "single-instance",
            "stage": "10default",
            "descriptor": {
              "Resources": {
                "Instance": {
                  "Properties": {
                    "InstanceType": "t2.medium",
                    "ImageId": {}
                  }
                },
                "Metadata": {
                  "AWS::CloudFormation::Init": {
                    "app": {
                      "packages": {
                        "yum": {
                          "tmux": [],
                          "vim": []
                        }
                      },
                      "files": {
                        "sources": {},
                        "commands": {},
                        "services": {}
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": [
          "server1 : type,stage,descriptor",
          "server2 : type,stage,descriptor"
        ]
      }
    ],
    "identifier": 53616327
  },
  {
    "context": [
      "How can I get all values with key `foo`, wherever they are?",
      "You can search using [recursive decent][1]",
      "jq '..|.foo?'"
    ],
    "utterance": "List all values whose key is foo, including at any nested level.",
    "expressions": [
      "..|.foo?"
    ],
    "data": [
      {
        "input": {
          "hello": {
            "foo": "x",
            "y": "z"
          },
          "foo": "a",
          "bar": [
            {
              "foo": "b"
            }
          ]
        },
        "output": [
          "x",
          "a",
          "b"
        ]
      }
    ],
    "identifier": 53733671
  },
  {
    "context": [
      "How do I get `myusername` and `mypassword` out of that?",
      "Ok, this seems to work, but should I be piping it back into jq like this? Feels like im doing it wrong:",
      "jq '.SecretString' -r | jq '.username' -r",
      "To parse it, simply use `fromjson`, so you could, for example, obtain the username with:",
      ".SecretString | fromjson | .username"
    ],
    "utterance": "Extract the value of the username key from the SecretString property, where SecretString contains a stringified object with keys username and password.",
    "expressions": [
      ".SecretString | fromjson | .username"
    ],
    "data": [
      {
        "input": {
          "ARN": "sdfsdfsdfsdfds",
          "Name": "sdfsdfsdfsdsf",
          "VersionId": "sdfsdfsdfsdfsdf",
          "SecretString": "{\"username\":\"myusername\",\"password\":\"mypassword\"}",
          "VersionStages": [
            "AWSCURRENT"
          ],
          "CreatedDate": 1541641750.607
        },
        "output": "myusername"
      }
    ],
    "identifier": 53200945
  },
  {
    "context": [
      "For example, the LotSize variable is in square feet (need to divide by 43560 to get acres, which is more conventional), and dateSold is a Linux timestamp.",
      "I\u2019d like to transform the JSON data above into something like this:\n\n    {\n    \t\"acres\": 1.5,\n    \t\"soldOn\": \"Friday, April 11, 2008\"\n    }",
      "jq -c '{acres: (.lotsize/43560), soldOn: (.dateSold | strftime(\"%A %B %d, %Y\")) }'",
      "produces:\n\n    {\"acres\":1.5,\"soldOn\":\"Friday April 11, 2008\"}"
    ],
    "utterance": "Convert lotsize from square feet to acres and format dateSold timestamp as a human-readable date string in the form 'Friday, April 11, 2008'.",
    "expressions": [
      "{acres: (.lotsize/43560), soldOn: (.dateSold | strftime(\"%A %B %d, %Y\")) }"
    ],
    "data": [
      {
        "input": {
          "lotsize": 65340,
          "dateSold": 1207897200
        },
        "output": {
          "acres": 1.5,
          "soldOn": "Friday April 11, 2008"
        }
      }
    ],
    "identifier": 53473584
  },
  {
    "context": [
      "I need to extract a key value with jq, only if key name is `Name`.",
      "I have some AMI's that don't have a key name of `Name` and I want to ignore them.",
      "You can use `select`:\r\n\r\n    jq -r '.Snapshots[].Tags[] | select(.Key == \"Name\").Value'"
    ],
    "utterance": "Extract the tag value where the tag key is Name in each snapshot, ignoring items without such a tag.",
    "expressions": [
      ".Snapshots[].Tags[] | select(.Key == \"Name\").Value"
    ],
    "data": [
      {
        "input": {
          "Snapshots": [
            {
              "Description": "AMI upgrader",
              "Tags": [
                {
                  "Value": "AMI upgrader",
                  "Key": "Name"
                }
              ],
              "Encrypted": false,
              "VolumeId": "vol-9356e811",
              "State": "completed",
              "VolumeSize": 20,
              "StartTime": "2018-05-31T13:58:31.000Z",
              "Progress": "100%",
              "OwnerId": "1234",
              "SnapshotId": "snap-1234"
            }
          ]
        },
        "output": "AMI upgrader"
      }
    ],
    "identifier": 53578837
  },
  {
    "context": [
      "My problem is to make `jq` stop reading after first object is read, and do not touch other data in stream (fifo). So `cat` should show the rest of data: `'{\"x\":33}{\"asd\":889}'`.",
      "jq -n 'input | stderr | inputs' <&3 2>first 1>rest",
      "Input is processed in a streaming fashion (one input value at a time) and you can pipe `stdout` and/or `stderr` to something else. Though the whole input has to be valid JSON and it will be prettified while passing through `jq` (unlike with cat above)."
    ],
    "utterance": "Output the first object from an input stream to one file and the remaining objects to another file.",
    "expressions": [
      "jq -n 'input | stderr | inputs' <&3 2>first 1>rest"
    ],
    "data": [
      {
        "input": "{ \"a\": 0, \"b\": { \"c\": \"C\" } }{ \"x\": 33 }{ \"asd\": 889 }",
        "output": null
      }
    ],
    "identifier": 53732698
  },
  {
    "context": [
      "I\u0019d like to use jq to change this response into proper json rather than a list of headers and a row of data corresponding to the items in the list:\r\n\r\n    {\"A\": \"1\", \"B\": \"2\", \"C\" : null, \"D\": \"4\"}",
      "What's the right syntax for \r\n\r\n    [[HEADER1,HEADER2,...]\\n\r\n    [DATA1,DATA2]] \r\n\r\nresponses into json?",
      "sed 's/\\\\\"/\"/;1s/\\\\n/,/' input.txt | jq '\r\n  .[0] as $h\r\n  | .[1] \r\n  | . as $in\r\n  | reduce range(0;length) as $i\r\n      ({}; .[$h[$i]] = $in[$i])'",
      "jq -Rs < input.txt '\r\n  split(\"\\n\")\r\n  | map(select(length>0))\r\n  | ( .[0] | sub(\"[[]\\\\\\\"; \"\") | sub(\"\\\\\\n\"; \"\") | fromjson) as $h\r\n  | .[1]\r\n  | sub(\"\\\\]\\\\]\"; \"]\")\r\n  | fromjson\r\n  | . as $in\r\n  | reduce range(0;length) as $i\r\n      ({}; .[$h[$i]] = $in[$i])'"
    ],
    "utterance": "Transform a two-element array where the first element is a list of header names and the second is a list of corresponding values into an object mapping each header to its value.",
    "expressions": [
      ".[0] as $h | .[1] as $in | reduce range(0;length) as $i ({}; .[$h[$i]] = $in[$i])"
    ],
    "data": [
      {
        "input": [
          [
            "A",
            "B",
            "C",
            "D"
          ],
          [
            "1",
            "2",
            null,
            "4"
          ]
        ],
        "output": {
          "A": "1",
          "B": "2",
          "C": null,
          "D": "4"
        }
      }
    ],
    "identifier": 53383105
  },
  {
    "context": [
      "I want to extract the `processid` from each sub-object.",
      "They all have in common the initial word `Task`.",
      "Filter keys that start with `Test` and get only the attribute of your choice using the `select()` expression",
      "jq 'to_entries[] | select(.key|startswith(\"Task\")).value.attributes.processid' json"
    ],
    "utterance": "Extract the processid values from all top-level fields whose keys start with Task.",
    "expressions": [
      "to_entries[] | select(.key | startswith(\"Task\")).value.attributes.processid"
    ],
    "data": [
      {
        "input": {
          "Task11c-0-20181209-12:59:30-65611": {
            "attributes": {
              "configname": "Task11c",
              "datetime": "20181209-12:59:30",
              "experiment": "Task11c",
              "inifile": "lab1.ini",
              "iterationvars": "",
              "iterationvarsf": "",
              "measurement": "",
              "network": "Manhattan1_1C",
              "processid": "65611",
              "repetition": "0",
              "replication": "#0",
              "resultdir": "results",
              "runnumber": "0",
              "seedset": "0"
            }
          },
          "Task11b-12-20181209-13:03:17-65612": {
            "attributes": {
              "configname": "Task11b",
              "datetime": "20181209-13:03:17",
              "experiment": "Task11b",
              "inifile": "lab2.ini",
              "processid": "65612"
            }
          },
          "OtherField": {
            "attributes": {
              "processid": "99999"
            }
          }
        },
        "output": [
          "65611",
          "65612"
        ]
      }
    ],
    "identifier": 53721635
  },
  {
    "context": [
      "I want to replace the number following \"nStrains\": with the lines in file `a2`. The desired output is:",
      "Better use [tag:jq] to manipulate JSON data.",
      "jq '.species |= (\n        to_entries | map(.value.nStrains = $repl[.key]) |\n        reduce .[] as $item ([]; .[$item.key] = $item.value)\n    )' --argfile repl a2 config",
      "Note that the -n option is needed because `inputs` is used.  The -R option is used mainly because the requirements implicitly specify that the replacement values should be strings",
      "jq -Rn --argfile config config.json -f update.jq a2",
      "[inputs] as $dict\n| $config\n| .species |= [to_entries[] | (.value.nStrains = $dict[.key]) | .value]"
    ],
    "utterance": "Replace each nStrains value in all elements of the species array with corresponding lines from a separate file, preserving string type.",
    "expressions": [
      ".species |= (to_entries | map(.value.nStrains = $repl[.key]) | reduce .[] as $item ([]; .[$item.key] = $item.value))",
      "[inputs] as $dict | $config | .species |= [to_entries[] | (.value.nStrains = $dict[.key]) | .value]"
    ],
    "identifier": 53721334
  },
  {
    "context": [
      "I have the following json array of objects. I am looking to change this to an array of keys. The values of the keys should be the object.",
      "The following is the desired output.",
      "I'd need to grab the value of the repo_name key from each object somehow. Is this possible?",
      "The following filter produces results in the desired format, but the output marked in the Q as \"desired\" does not exactly match the given input, which I take to be an oversight.",
      "{repos: map( {(.repo_name): del(.repo_name)} )}"
    ],
    "utterance": "Reformat an array of objects so that each object becomes a key-value pair where the key is the value of repo_name and the value is the original object minus the repo_name field, nesting all these key-value pairs in a repos array of objects.",
    "expressions": [
      "{repos: map( {(.repo_name): del(.repo_name)} )}"
    ],
    "data": [
      {
        "input": [
          {
            "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:14:05 2018)",
            "repo_url": "http://repos.blah.com/CentOS/dev/6/os/x86_64/",
            "repo_tstsync": 0,
            "repo_id": "base",
            "repo_pkgs": "6,713",
            "repo_prdsync": 0,
            "repo_revision": 1530286202,
            "repo_name": "CentOS-6 - Base",
            "repo_size": "5.5 G",
            "repo_updated": "Fri Jun 29 08:37:23 2018"
          },
          {
            "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:36:50 2018)",
            "repo_url": "http://blah.com/epel/dev/6/x86_64/",
            "repo_tstsync": 0,
            "repo_id": "epel",
            "repo_pkgs": "12,448",
            "repo_prdsync": 699,
            "repo_revision": 1542329363,
            "repo_name": "Extra Packages for Enterprise Linux 6 - x86_64",
            "repo_size": "11 G",
            "repo_updated": "Thu Nov 15 17:50:18 2018"
          },
          {
            "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:44:05 2018)",
            "repo_url": "http://blah.com/CentOS/dev/6/extras/x86_64/",
            "repo_tstsync": "null",
            "repo_id": "extras",
            "repo_pkgs": 33,
            "repo_prdsync": "null",
            "repo_revision": 1537445728,
            "repo_name": "CentOS-6 - Extras",
            "repo_size": "12 M",
            "repo_updated": "Thu Sep 20 05:15:29 2018"
          }
        ],
        "output": {
          "repos": [
            {
              "CentOS-6 - Base": {
                "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:14:05 2018)",
                "repo_url": "http://repos.blah.com/CentOS/dev/6/os/x86_64/",
                "repo_tstsync": 0,
                "repo_id": "base",
                "repo_pkgs": "6,713",
                "repo_prdsync": 0,
                "repo_revision": 1530286202,
                "repo_size": "5.5 G",
                "repo_updated": "Fri Jun 29 08:37:23 2018"
              },
              "Extra Packages for Enterprise Linux 6 - x86_64": {
                "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:36:50 2018)",
                "repo_url": "http://blah.com/epel/dev/6/x86_64/",
                "repo_tstsync": 0,
                "repo_id": "epel",
                "repo_pkgs": "12,448",
                "repo_prdsync": 699,
                "repo_revision": 1542329363,
                "repo_size": "11 G",
                "repo_updated": "Thu Nov 15 17:50:18 2018"
              },
              "CentOS-6 - Extras": {
                "repo_expire": "21,600 second(s) (last: Tue Nov 20 07:44:05 2018)",
                "repo_url": "http://blah.com/CentOS/dev/6/extras/x86_64/",
                "repo_tstsync": "null",
                "repo_id": "extras",
                "repo_pkgs": 33,
                "repo_prdsync": "null",
                "repo_revision": 1537445728,
                "repo_size": "12 M",
                "repo_updated": "Thu Sep 20 05:15:29 2018"
              }
            }
          ]
        }
      }
    ],
    "identifier": 53399168
  },
  {
    "context": [
      "I have my data in the following json array:\r\n\r\n    [{ \"min\": 1, \"max\": 2},\r\n     { \"min\": 5, \"max\": 6}]\r\n\r\n\r\n\r\nand I would need to have it in the format:\r\n\r\n    1-2,5-6",
      "jq -r 'map(\"\\(.min)-\\(.max)\") | join(\",\")' file.json",
      "jq -r 'map([.min, .max|tostring] | join(\"-\")) | join(\",\")' input.json\r\n    1-2,5-6"
    ],
    "utterance": "Combine each element's min and max values with a hyphen and join all pairs with commas in the order given.",
    "expressions": [
      "map([.min, .max|tostring] | join(\"-\")) | join(\",\")",
      "map(\"\\(.min)-\\(.max)\") | join(\",\")",
      "map([.[]] | join(\"-\")) | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "min": 1,
            "max": 2
          },
          {
            "min": 5,
            "max": 6
          }
        ],
        "output": "1-2,5-6"
      }
    ],
    "identifier": 53709718
  },
  {
    "context": [
      "How could i achieve the following output result? (tsv)\r\n\r\n    13 T\u0399 UIH 2\r\n    13 AB KIO 1\r\n    17 GH SVS 1",
      "I was able to obtain the expected result from your sample JSON using the following :\r\n\r\n    group_by(.org, .rc.\"$event\")[] | [.[0].rc.\"$event\", .[0].org, length] | @tsv",
      "The modification of the `group_by` clause ensures we will have one entry by pair of `.org`/`.rc.$event` (without it we would only have one entry by `.org`, which might hide some `.rc.$event`).",
      "To sort the result, you can put it in an array and use `sort_by(.[0])` which will sort by the first element of the rows :\r\n\r\n    [group_by(.org, .rc.\"$event\")[] | [.[0].rc.\"$event\", .[0].org, length]] | sort_by(.[0])[] | @tsv"
    ],
    "utterance": "Group the entries by both the org and rc.$event fields and output lines with rc.$event, org, and the count of items in each group in tab-separated format.",
    "expressions": [
      "group_by(.org, .rc.\"$event\")[] | [.[0].rc.\"$event\", .[0].org, length] | @tsv",
      "[group_by(.org, .rc.\"$event\")[] | [.[0].rc.\"$event\", .[0].org, length]] | sort_by(.[0])[] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d2"
            },
            "org": "T\u0399 UIH",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d3"
            },
            "org": "T\u0399 UIH",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d4"
            },
            "org": "AB KIO",
            "rc": {
              "$event": "13"
            }
          },
          {
            "us": {
              "$event": "5bbf4a4f43d8950b5b0cc6d5"
            },
            "org": "GH SVS",
            "rc": {
              "$event": "17"
            }
          }
        ],
        "output": "13\tT\u0399 UIH\t2\n13\tAB KIO\t1\n17\tGH SVS\t1"
      }
    ],
    "identifier": 53229452
  },
  {
    "context": [
      "Command as simple as `jq . *.json` is failing with following error:",
      "> Assertion failed!",
      "So assuming you can't simply process the files one at a time, you'll either have to create the list of files explicitly, or use a different shell.",
      "But remember that in `cmd` and batch files your command lines are limited to 8191 characters. If it is not enough to deal with your problem you can try with something like (yes, a lot of lines, most of them comments and command usage)",
      "dir /b *.json | list2args.cmd jq .",
      "However if you just want to make it work, I recommend using [Windows Subsystem for Linux (WSL)](https://learn.microsoft.com/en-us/windows/wsl/install), or [Git Bash](https://gitforwindows.org/). Both of these handle wildcard expansion trivially after initial setup."
    ],
    "utterance": "Process all files in the current directory matching the .json extension using jq on Windows, working around cmd.exe's lack of wildcard expansion.",
    "expressions": [
      "for %f in (*.json) do jq . \"%f\"",
      "dir /b *.json | list2args.cmd jq ."
    ],
    "identifier": 53387811
  },
  {
    "context": [
      "I have the following file ( vms.json ) that i am trying to convert csv while adding the disk size element.",
      "host1,running,linux,62277025792",
      "host2,running,linux,39519165044",
      "Given your input and an invocation of jq with the -r option, the following filter:",
      ".vms[] | [.hostname, .state, .platform, (.Disks | map(.size|tonumber) | add)] | join(\",\")"
    ],
    "utterance": "Produce CSV rows of hostname, state, platform, and the total sum of all disk sizes for each VM.",
    "expressions": [
      ".vms[] | [.hostname, .state, .platform, (.Disks | map(.size|tonumber) | add)] | join(\",\")",
      ".vms[] | [.hostname, .state, .platform, (.Disks | map(.size|tonumber) | add)] | @csv"
    ],
    "data": [
      {
        "input": {
          "vms": [
            {
              "hostname": "host1",
              "state": "running",
              "platform": "linux",
              "Disks": [
                {
                  "index": 1,
                  "volume_name": "/boot",
                  "size": "34359738368"
                },
                {
                  "index": 2,
                  "volume_name": "/data",
                  "size": "27917287424"
                }
              ]
            },
            {
              "hostname": "host2",
              "state": "running",
              "platform": "linux",
              "Disks": [
                {
                  "index": 1,
                  "volume_name": "/boot",
                  "size": "34359738368"
                },
                {
                  "index": 2,
                  "volume_name": "/user_data",
                  "size": "5159324276"
                },
                {
                  "index": 3,
                  "volume_name": "/temporary",
                  "size": "102400"
                }
              ]
            }
          ]
        },
        "output": [
          "host1,running,linux,62277025792",
          "host2,running,linux,39519165044"
        ]
      }
    ],
    "identifier": 53163379
  },
  {
    "context": [
      "Cool, But I want to toal both fields, something like:",
      "reduce .usage.\"os:linux\"[] as $item (\n{\"credits\":0,\"minutes\":0}; \n.\"credits\" += $item.credits,\n.\"minutes\" += $item.amount /1000/60\n)",
      "Semi-colons cause errors, commas pass, but just handles the last task, i,e,",
      "There's always the explicit way:\n\n    reduce .usage.\"os:linux\"[] as $item (\n      {\"credits\": 0, \"minutes\": 0 }; \n      {\n        \"credits\": (.credits + $item.credits),\n        \"minutes\": (.minutes + $item.amount / 60000) \n      }\n    )",
      "Or more succintly:\n\n    reduce .usage.\"os:linux\"[] as $item (\n      {}; \n      .credits += $item.credits\n      | .minutes += ($item.amount / 60000) )",
      "Or abstracting the reduction into the general-purpose utility function `sigma/1`:\n\ndef sigma(s): reduce s as $s (null; . + $s);\n\n.usage.\"os:linux\"\n| {credits: sigma(.[].credits),\n   minutes: (sigma(.[].amount) / 60000) }"
    ],
    "utterance": "Sum all credits and calculate total minutes (amount divided by 60000) for each entry under usage.os:linux, returning an object with both totals.",
    "expressions": [
      "reduce .usage.\"os:linux\"[] as $item (\n  {\"credits\": 0, \"minutes\": 0 }; \n  {\n    \"credits\": (.credits + $item.credits),\n    \"minutes\": (.minutes + $item.amount / 60000) \n  }\n)",
      "reduce .usage.\"os:linux\"[] as $item (\n  {}; \n  .credits += $item.credits\n  | .minutes += ($item.amount / 60000) )",
      "def sigma(s): reduce s as $s (null; . + $s);\n\n.usage.\"os:linux\"\n| {credits: sigma(.[].credits),\n   minutes: (sigma(.[].amount) / 60000) }"
    ],
    "data": [
      {
        "input": {
          "usage": {
            "os:linux": {
              "2018_11_18": {
                "amount": 601046342,
                "credits": 99783
              },
              "2018_10_18": {
                "amount": 839785106,
                "credits": 173121
              }
            }
          }
        },
        "output": {
          "credits": 272904,
          "minutes": 24013.857466666665
        }
      }
    ],
    "identifier": 53420046
  },
  {
    "context": [
      "I'm fetching the shared property \"region\" from the data1, and trying to find the matching one in data2.",
      "select with parameter not working :(",
      "matching_obj=$(jq -c  '.[] | select(.region==\"$crgn\") ' <<< \"$data2\")",
      "I had to use single-quotes. not double quotes. and no need to named parameters.",
      "matching_obj=$(jq -c '.[] | select(.region=='$current_region')' <<< \"$data2\")"
    ],
    "utterance": "For each object in data1, find objects in data2 where the region value matches.",
    "expressions": [
      ".[] | select(.region==$current_region)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "domain": "domain1",
              "region": "region1"
            },
            {
              "domain": "domain2",
              "region": "region2"
            },
            {
              "domain": "domain3",
              "region": "region3"
            }
          ],
          [
            {
              "region": "eustaging1",
              "secret": "s1"
            },
            {
              "region": "eustaging2",
              "secret": "s2"
            },
            {
              "region": "eustaging2",
              "secret": "s3"
            }
          ]
        ]
      }
    ],
    "identifier": 53691243
  },
  {
    "context": [
      "I need to group by nested structures in a JSON file and flatten the nested structures",
      "The way it should look at the end result would be with one flattened entry for each \"action\" in the nested arrays under \"actionDetails\"",
      "An example of how the first entry in the original JSON should look afterwards is: [ { \"timestamp\": 84615195, ... }, ... ]",
      "As I understand it, you want some grouping to take place after the flattening based on .actionDetails.",
      ".[] | .actionDetails[] + (del(.actionDetails) | del(.customVariables) | del(.pluginsIcons))"
    ],
    "utterance": "Flatten each object so there is one entry per element in the 'actionDetails' array, merging properties from the main object except for 'actionDetails', 'customVariables', and 'pluginsIcons'.",
    "expressions": [
      ".[] | .actionDetails[] + (del(.actionDetails) | del(.customVariables) | del(.pluginsIcons))"
    ],
    "data": [
      {
        "input": [
          {
            "Value1": "0",
            "Conversions": "0",
            "Revenue": "0.00",
            "serverTimestamp": 84615198,
            "pluginsIcons": [
              {
                "pluginName": "pdf",
                "pluginIcon": "pdf1"
              },
              {
                "pluginName": "java",
                "pluginIcon": "java1"
              }
            ],
            "plugins": "pdf, java",
            "customVariables": {
              "3": {
                "customVariableValue3": "F",
                "customVariableName3": "Gender"
              },
              "2": {
                "customVariableValue2": "Person",
                "customVariableName2": "Role"
              },
              "1": {
                "customVariableValue1": "Partner1",
                "customVariableName1": "Partner"
              }
            },
            "interactions": "7",
            "actions": "3",
            "actionDetails": [
              {
                "timestamp": 84615195,
                "interactionPosition": "1",
                "type": "action"
              },
              {
                "timestamp": 84615145,
                "interactionPosition": "2",
                "type": "action"
              },
              {
                "timestamp": 84615693,
                "interactionPosition": "3",
                "type": "action",
                "customVariables": {
                  "2": {
                    "customVariablePageValue2": "value2",
                    "customVariablePageName2": "name2"
                  },
                  "1": {
                    "customVariablePageValue1": "value1",
                    "customVariablePageName1": "name1"
                  }
                }
              }
            ],
            "operatingSystem": "Windows 10"
          }
        ],
        "output": [
          {
            "timestamp": 84615195,
            "interactionPosition": "1",
            "type": "action",
            "Value1": "0",
            "Conversions": "0",
            "Revenue": "0.00",
            "serverTimestamp": 84615198,
            "plugins": "pdf, java",
            "interactions": "7",
            "actions": "3",
            "operatingSystem": "Windows 10"
          },
          {
            "timestamp": 84615145,
            "interactionPosition": "2",
            "type": "action",
            "Value1": "0",
            "Conversions": "0",
            "Revenue": "0.00",
            "serverTimestamp": 84615198,
            "plugins": "pdf, java",
            "interactions": "7",
            "actions": "3",
            "operatingSystem": "Windows 10"
          },
          {
            "timestamp": 84615693,
            "interactionPosition": "3",
            "type": "action",
            "customVariables": {
              "2": {
                "customVariablePageValue2": "value2",
                "customVariablePageName2": "name2"
              },
              "1": {
                "customVariablePageValue1": "value1",
                "customVariablePageName1": "name1"
              }
            },
            "Value1": "0",
            "Conversions": "0",
            "Revenue": "0.00",
            "serverTimestamp": 84615198,
            "plugins": "pdf, java",
            "interactions": "7",
            "actions": "3",
            "operatingSystem": "Windows 10"
          }
        ]
      }
    ],
    "identifier": 53630450
  },
  {
    "context": [
      "i have two json files structured like that:",
      "file 1",
      "[ { \"id\": 25422, \"location\": \"Hotel X\", \"suppliers\": [ 12 ] }, { \"id\": 25423, \"location\": \"Hotel Y\", \"suppliers\": [ 13 ] }]",
      "file 2",
      "[ { \"id\": 12, \"vatNumber\": \"0000000000\" }, { \"id\": 14, \"vatNumber\": \"0000000001\" }]",
      "and i'd like a result like this",
      "[ { \"id\": 25422, \"location\": \"Hotel X\", \"suppliers\": [ 12 ], \"vatNumber\": \"0000000000\" }, { \"id\": 25423, \"location\": \"Hotel Y\", \"suppliers\": [ 13 ] }]",
      "The important thing to me is that the matching vatNumbers, are set in the first file.",
      "Here&#39;s one of many possible solutions.",
      "jq -n --argfile f1 file1.json --argfile f2 file2.json -f merge.jq",
      "merge.jq:",
      "INDEX($f2[] ; .id) as $dict | $f1 | map( ($dict[.suppliers[0]|tostring]|.vatNumber) as $vn | if $vn then .vatNumber = $vn else . end)"
    ],
    "utterance": "Attach vatNumber from the second file to each object from the first file where the first supplier id matches an id in the second file.",
    "expressions": [
      "INDEX($f2[] ; .id) as $dict | $f1 | map( ($dict[.suppliers[0]|tostring]|.vatNumber) as $vn | if $vn then .vatNumber = $vn else . end)"
    ],
    "data": [
      {
        "input": {
          "file1": [
            {
              "id": 25422,
              "location": "Hotel X",
              "suppliers": [
                12
              ]
            },
            {
              "id": 25423,
              "location": "Hotel Y",
              "suppliers": [
                13
              ]
            }
          ],
          "file2": [
            {
              "id": 12,
              "vatNumber": "0000000000"
            },
            {
              "id": 14,
              "vatNumber": "0000000001"
            }
          ]
        },
        "output": [
          {
            "id": 25422,
            "location": "Hotel X",
            "suppliers": [
              12
            ],
            "vatNumber": "0000000000"
          },
          {
            "id": 25423,
            "location": "Hotel Y",
            "suppliers": [
              13
            ]
          }
        ]
      }
    ],
    "identifier": 53618118
  },
  {
    "context": [
      "given the following json, how could i create a tsv, that would output the frequencies of the values found in it (in the new element)?",
      "desired output:\r\n\r\n    813 ROT 2\r\n    9878 SU 1",
      "i can extract the values with .new, but do not know how to group them and create the tsv then",
      "You can try this jq filter:\r\n\r\n    jq -sr 'group_by(.new)|.[]|[.[0].new, length]|@tsv'\r\n    813 ROT 2\r\n    9878 SU 1"
    ],
    "utterance": "Output all unique values of the 'new' field along with their frequency as tab-separated values, with the value and count per line.",
    "expressions": [
      "group_by(.new)|.[]|[.[0].new, length]|@tsv"
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "$someid": "545"
            },
            "new": "813 ROT",
            "old": {
              "$someid": "5fe"
            }
          },
          {
            "_id": {
              "$someid": "659889a"
            },
            "new": "9878 SU",
            "old": {
              "$someid": "5bc"
            }
          },
          {
            "_id": {
              "$someid": "986978754b"
            },
            "new": "813 ROT",
            "old": {
              "$someid": "5bc1af"
            }
          }
        ],
        "output": "813 ROT\t2\n9878 SU\t1"
      }
    ],
    "identifier": 53225044
  },
  {
    "context": [
      "Is there a way I can get the second method's formatting, but return all the instances like the first method gives me? I suppose for the tag that doesn't exist in one of the instances, usage would be empty or null.",
      "You can try this jq filter:\n\n    jq '.[]|{id,env:.ENVIRONMENT[],usage:(.Usage[]//null),name:.Name[]}' file",
      "If you just want the first item in each array, then you could use .[0] as follows:\n\n    .[]\n    | {id, env: .ENVIRONMENT[0], usage: .Usage[0], name: .Name[0]}"
    ],
    "utterance": "For each object, display id, each ENVIRONMENT as env, corresponding Usage as usage (or null if missing), and each Name as name in an object format; show all such combinations for all instances.",
    "expressions": [
      ".[] | {id, env: .ENVIRONMENT[], usage: (.Usage[] // null), name: .Name[]}",
      ".[] | {id, env: .ENVIRONMENT[0], usage: .Usage[0], name: .Name[0]}"
    ],
    "data": [
      {
        "input": [
          {
            "ENVIRONMENT": [
              "sit"
            ],
            "Usage": [],
            "id": "i-098a99bd2bd0ac86b",
            "Name": [
              "instance1"
            ]
          },
          {
            "ENVIRONMENT": [
              "uat"
            ],
            "Usage": [
              "testing"
            ],
            "id": "i-0b210876db6d028f3",
            "Name": [
              "instance2"
            ]
          }
        ],
        "output": [
          {
            "id": "i-098a99bd2bd0ac86b",
            "env": "sit",
            "usage": null,
            "name": "instance1"
          },
          {
            "id": "i-0b210876db6d028f3",
            "env": "uat",
            "usage": "testing",
            "name": "instance2"
          }
        ]
      }
    ],
    "identifier": 53229035
  },
  {
    "context": [
      "I need to extract (parse) them into two formats:",
      "1) Each value separated by comma.",
      "2) Only the first value before the first space.",
      "1) Separate the cipher values by commas and if there is an `=` sign, take what comes after it:",
      "2) Extract just the first part of the `cipher` value which is:",
      "There is a slight mismatch between the given JSON input, the stated requirements, and the expected output, so I will focus on the requirements and the given input.",
      "## (1)",
      ".[] | .cipher |= gsub(\" *(?<x>[A-Za-z]+)=(?<y>[^ ]+)\"; \",\" + .y) | .cipher |= (split(\" |,\") | join(\",\")) | \"\\(.host),\\(.ip),\\(.cipher)\"",
      "produces",
      "xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2,ECDH,RSA,AESGCM(128),AEAD",
      "## (2)",
      ".[] | .cipher |= (split(\" \")[0]) | \"\\(.host),\\(.ip),\\(.cipher)\"",
      "produces",
      "xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256"
    ],
    "utterance": "Produce a line for each object containing host, ip, and cipher; once with the cipher split into comma-separated values, extracting values after '=', and once with only the first cipher field before the first space.",
    "expressions": [
      ".[] | .cipher |= gsub(\" *(?<x>[A-Za-z]+)=(?<y>[^ ]+)\"; \",\" + .y) | .cipher |= (split(\" |,\") | join(\",\")) | \"\\(.host),\\(.ip),\\(.cipher)\"",
      ".[] | .cipher |= (split(\" \")[0]) | \"\\(.host),\\(.ip),\\(.cipher)\""
    ],
    "data": [
      {
        "input": [
          {
            "host": "xys.com",
            "ip": "0.20.0.4",
            "port": 222,
            "cipher": "ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2 Kx=ECDH     Au=RSA  Enc=AESGCM(128) Mac=AEAD"
          }
        ],
        "output": [
          "xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2,ECDH,RSA,AESGCM(128),AEAD",
          "xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256"
        ]
      }
    ],
    "identifier": 53684343
  },
  {
    "context": [
      "First we curl the url to get the user object and add a new field to it.",
      "curl -s https://jsonplaceholder.typicode.com/users/1 | jq '. + {\"level\": 15}'",
      "Second we add that user object to the list in userList.json. This is the part that I'm stumped on.",
      "Expected result of userList.json file, it's the 4 user objects with an added field level.",
      "curl -s ${testUrl} | jq '. + {level: 15}' >> /tmp/temp_user_${i}_information_file.json",
      "jq -s '.' /tmp/temp_user_*_information_file.json > userList.json"
    ],
    "utterance": "Combine multiple user objects, each with an added 'level: 15' field, into a single array in a file; each user object is retrieved separately and transformed before aggregation.",
    "expressions": [
      "jq '. + {level: 15}'",
      "jq -s '.' /tmp/temp_user_*_information_file.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "Leanne Graham",
            "username": "Bret",
            "email": "Sincere@april.biz",
            "address": {
              "street": "Kulas Light",
              "suite": "Apt. 556",
              "city": "Gwenborough",
              "zipcode": "92998-3874",
              "geo": {
                "lat": "-37.3159",
                "lng": "81.1496"
              }
            },
            "phone": "1-770-736-8031 x56442",
            "website": "hildegard.org",
            "company": {
              "name": "Romaguera-Crona",
              "catchPhrase": "Multi-layered client-server neural-net",
              "bs": "harness real-time e-markets"
            }
          },
          {
            "id": 2,
            "name": "Ervin Howell",
            "username": "Antonette",
            "email": "Shanna@melissa.tv",
            "address": {
              "street": "Victor Plains",
              "suite": "Suite 879",
              "city": "Wisokyburgh",
              "zipcode": "90566-7771",
              "geo": {
                "lat": "-43.9509",
                "lng": "-34.4618"
              }
            },
            "phone": "010-692-6593 x09125",
            "website": "anastasia.net",
            "company": {
              "name": "Deckow-Crist",
              "catchPhrase": "Proactive didactic contingency",
              "bs": "synergize scalable supply-chains"
            }
          },
          {
            "id": 3,
            "name": "Clementine Bauch",
            "username": "Samantha",
            "email": "Nathan@yesenia.net",
            "address": {
              "street": "Douglas Extension",
              "suite": "Suite 847",
              "city": "McKenziehaven",
              "zipcode": "59590-4157",
              "geo": {
                "lat": "-68.6102",
                "lng": "-47.0653"
              }
            },
            "phone": "1-463-123-4447",
            "website": "ramiro.info",
            "company": {
              "name": "Romaguera-Jacobson",
              "catchPhrase": "Face to face bifurcated interface",
              "bs": "e-enable strategic applications"
            }
          },
          {
            "id": 4,
            "name": "Patricia Lebsack",
            "username": "Karianne",
            "email": "Julianne.OConner@kory.org",
            "address": {
              "street": "Hoeger Mall",
              "suite": "Apt. 692",
              "city": "South Elvis",
              "zipcode": "53919-4257",
              "geo": {
                "lat": "29.4572",
                "lng": "-164.2990"
              }
            },
            "phone": "493-170-9623 x156",
            "website": "kale.biz",
            "company": {
              "name": "Robel-Corkery",
              "catchPhrase": "Multi-tiered zero tolerance productivity",
              "bs": "transition cutting-edge web services"
            }
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "Leanne Graham",
            "username": "Bret",
            "email": "Sincere@april.biz",
            "address": {
              "street": "Kulas Light",
              "suite": "Apt. 556",
              "city": "Gwenborough",
              "zipcode": "92998-3874",
              "geo": {
                "lat": "-37.3159",
                "lng": "81.1496"
              }
            },
            "phone": "1-770-736-8031 x56442",
            "website": "hildegard.org",
            "company": {
              "name": "Romaguera-Crona",
              "catchPhrase": "Multi-layered client-server neural-net",
              "bs": "harness real-time e-markets"
            },
            "level": 15
          },
          {
            "id": 2,
            "name": "Ervin Howell",
            "username": "Antonette",
            "email": "Shanna@melissa.tv",
            "address": {
              "street": "Victor Plains",
              "suite": "Suite 879",
              "city": "Wisokyburgh",
              "zipcode": "90566-7771",
              "geo": {
                "lat": "-43.9509",
                "lng": "-34.4618"
              }
            },
            "phone": "010-692-6593 x09125",
            "website": "anastasia.net",
            "company": {
              "name": "Deckow-Crist",
              "catchPhrase": "Proactive didactic contingency",
              "bs": "synergize scalable supply-chains"
            },
            "level": 15
          },
          {
            "id": 3,
            "name": "Clementine Bauch",
            "username": "Samantha",
            "email": "Nathan@yesenia.net",
            "address": {
              "street": "Douglas Extension",
              "suite": "Suite 847",
              "city": "McKenziehaven",
              "zipcode": "59590-4157",
              "geo": {
                "lat": "-68.6102",
                "lng": "-47.0653"
              }
            },
            "phone": "1-463-123-4447",
            "website": "ramiro.info",
            "company": {
              "name": "Romaguera-Jacobson",
              "catchPhrase": "Face to face bifurcated interface",
              "bs": "e-enable strategic applications"
            },
            "level": 15
          },
          {
            "id": 4,
            "name": "Patricia Lebsack",
            "username": "Karianne",
            "email": "Julianne.OConner@kory.org",
            "address": {
              "street": "Hoeger Mall",
              "suite": "Apt. 692",
              "city": "South Elvis",
              "zipcode": "53919-4257",
              "geo": {
                "lat": "29.4572",
                "lng": "-164.2990"
              }
            },
            "phone": "493-170-9623 x156",
            "website": "kale.biz",
            "company": {
              "name": "Robel-Corkery",
              "catchPhrase": "Multi-tiered zero tolerance productivity",
              "bs": "transition cutting-edge web services"
            },
            "level": 15
          }
        ]
      }
    ],
    "identifier": 53625680
  },
  {
    "context": [
      "EXAMPLE:\r\n\r\nThis works on Ubuntu for me, and need to make it work on Windows(just need the time difference in seconds).\r\n\r\n    jq -n '{\"t1\": \"2018-06-01 12:45:56\", \"t2\": \"2018-06-03 22:10:01\"} |\r\n           (.t2 | strptime(\"%Y-%m-%d %H:%M:%S\") | mktime)-\r\n           (.t1 | strptime(\"%Y-%m-%d %H:%M:%S\") | mktime)'\r\n    206645",
      "But I get this error while using `strptime` on Windows `jq`.\r\n\r\n> jq: error (at xxxx.json:xxx): strptime/1 not implemented on this platform",
      "I just found that even `mktime` generates same error for me on Windows. So I updated the question that I need just some way to compare the datetime of specific format in units of seconds(with or without using `strptime`).",
      "First, a \"plug-in\" implementation of jq's `mktime/0`: ...",
      "Next, to parse date strings of the form `\"2018-06-01 12:45:56\"`, you can easily use jq's `capture` (see the [jq manual][1]). ..."
    ],
    "utterance": "Find the difference in seconds between two strings in the format 'YYYY-MM-DD HH:MM:SS'.",
    "expressions": [
      ". as {t1, t2} |",
      "def mktime: # plug-in implementation from answer\n  def max: if .[0] > .[1] then .[0] else .[1] end;\n  def min: if .[0] > .[1] then .[1] else .[0] end;\n  def NDaysInMonth: [ 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n  . as [$y, $m, $d, $h, $mn, $s]\n  | if ($y < 0 or $m < 0 or $d < 1 or $h < 0 or $mn < 0 or $s < 0)\n    then null\n    else\n    1970 as $ye\n    | (if $y > $ye then 1 else -1 end) as $sign\n    | ([$y, $ye] | max) as $maxY\n    | ([$y, $ye] | min) as $minY\n    | reduce range($minY; $maxY) as $i ({nleapYears: 0};\n        if (($i % 100 != 0 and $i % 4 == 0) or $i % 400 == 0) then .nleapYears += 1 else . end)\n    | if ($m > 1) and (($y % 100 != 0 and $y % 4 == 0) or $y % 400 == 0)\n      then .nleapYears += $sign\n      else .\n      end\n    | .nleapYears |= ([0, .] | max)\n    | reduce range(0;$m) as $i (.monthsNDays = 0;\n        .monthsNDays += NDaysInMonth[$i])\n    | (($y - $ye) * 365 + $sign * .nleapYears + .monthsNDays + $d - 1) * 86400\n        + $h * 3600 + $mn * 60 + $s\n    end ;",
      "def parse_ts:\n  capture(\"(?<y>\\\\d{4})-(?<m>\\\\d{2})-(?<d>\\\\d{2}) (?<h>\\\\d{2}):(?<mn>\\\\d{2}):(?<s>\\\\d{2})\") |\n  [ .y|tonumber, (.m|tonumber)-1, .d|tonumber, .h|tonumber, .mn|tonumber, .s|tonumber ];",
      "(parse_ts(t2) | mktime) - (parse_ts(t1) | mktime)"
    ],
    "data": [
      {
        "input": {
          "t1": "2018-06-01 12:45:56",
          "t2": "2018-06-03 22:10:01"
        },
        "output": 206645
      }
    ],
    "identifier": 53409620
  },
  {
    "context": [
      "Now I have another file that maps the `feature` to `value`:\r\n\r\n    feature_a value_1\r\n    feature_b value_2\r\n\r\nSo I would like to insert the `value` into the first json file, according to the maps, resulting the following output:",
      "jq -Rs --argfile target source.json dict.txt '[ split(\"\\n\")[] | select(length>0)  | split(\" \")  | { (.[0]): .[1]} ]  | add) as $dict | $target | .features |= map(.value = $dict[.feature])'"
    ],
    "utterance": "Populate each feature's value field with the corresponding mapped value from an external mapping file.",
    "expressions": [
      "jq -Rs --argfile target source.json '([ split(\"\\n\")[] | select(length>0) | split(\" \") | { (.[0]): .[1]} ] | add) as $dict | $target | .features |= map(.value = $dict[.feature])' dict.txt"
    ],
    "data": [
      {
        "input": {
          "item": "item1",
          "features": [
            {
              "feature": "feature_a",
              "value": ""
            },
            {
              "feature": "feature_b",
              "value": ""
            }
          ]
        },
        "output": {
          "item": "item1",
          "features": [
            {
              "feature": "feature_a",
              "value": "value_1"
            },
            {
              "feature": "feature_b",
              "value": "value_2"
            }
          ]
        }
      }
    ],
    "identifier": 53181061
  },
  {
    "context": [
      "Given a JSON line\n\n    {\"a\":0,\"b\":{\"c\":\"C\"}}{\"x\":33}{\"asd\":889}\n\nof 3 independent JSON objects.",
      "And need to handle then one by one. It would be nice to have something like \n\n    echo \"$json\" | jq --first-one",
      "Expected output:\n\n    {\"a\":0,\"b\":{\"c\":\"C\"}}",
      "How to read only first object from input stream and do not touch the rest objects?",
      "If your jq has `input`, you could simply write:\n\n    echo '{\"a\":0,\"b\":{\"c\":\"C\"}}{\"x\":33}{\"asd\":889}' |\n      jq -n input",
      "If that is not an option, then by all means use the -s option, e.g. `jq -s '.[0]'`"
    ],
    "utterance": "Return only the first object from a stream containing multiple adjacent objects without consuming the rest.",
    "expressions": [
      "jq -n input",
      "jq -s '.[0]'"
    ],
    "data": [
      {
        "input": "{\"a\":0,\"b\":{\"c\":\"C\"}}{\"x\":33}{\"asd\":889}",
        "output": {
          "a": 0,
          "b": {
            "c": "C"
          }
        }
      }
    ],
    "identifier": 53496484
  },
  {
    "context": [
      "and i like to update the id value and obtain this result",
      "[{\"id\": \"coupon25422\"},{\"id\": \"coupon25423\"}]",
      "$ jq -c 'map(.id |= \"coupon\\(.)\")' <<< '[{\"id\": 25422},{\"id\": 25423}]'"
    ],
    "utterance": "Update all id values by prepending the string 'coupon' to each id number.",
    "expressions": [
      "map(.id |= \"coupon\\(.)\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": 25422
          },
          {
            "id": 25423
          }
        ],
        "output": [
          {
            "id": "coupon25422"
          },
          {
            "id": "coupon25423"
          }
        ]
      }
    ],
    "identifier": 53637610
  },
  {
    "context": [
      "I need to pull a list of AWS instances with their instance ID and public IP, and outputting that to a spread sheet in csv format.",
      "I would like to know how to use the JQ command to replace the commas with spaces (so csv can fit them in the same column) and also replace null values with a space (for aws instances with no public IP).",
      "To actually ensure that your IP addresses are passed to `@csv` as a single field, you may want to join them ahead-of-time; that might be something like:",
      "jq -r '\n  .Reservations[].Instances[]\n  | [ .InstanceId,\n      ([.NetworkInterfaces[].PrivateIpAddresses[].Association.PublicIp // null\n       ] | join(\",\"))\n    ] | @csv'"
    ],
    "utterance": "Get a list of AWS instance IDs and their associated public IPs, combining multiple public IPs into a single column and replacing missing values with a space, with fields formatted for spreadsheet CSV import.",
    "expressions": [
      ".Reservations[].Instances[] | [ .InstanceId, ([.NetworkInterfaces[].PrivateIpAddresses[].Association.PublicIp // \" \" ] | join(\" \")) ] | @csv"
    ],
    "identifier": 53677054
  },
  {
    "context": [
      "The key-pairs that have null need to be replaced with the corresponding `siteurl` within it's array.",
      "To copy `siteurl` from the first object:\r\n\r\n    jq '.[0].siteurl as $v | map(.siteurl = $v)' file.json"
    ],
    "utterance": "Replace all siteurl values in every object with the siteurl value from the first object in the array, especially where siteurl is null.",
    "expressions": [
      ".[0].siteurl as $v | map(.siteurl = $v)"
    ],
    "data": [
      {
        "input": [
          {
            "eventType": "WordpressSite",
            "siteurl": "http://mytest1.com"
          },
          {
            "eventType": "WordpressPlugin",
            "plugin_name": "akismet",
            "plugin_status": "inactive",
            "plugin_update": "available",
            "plugin_version": "4.0.8",
            "siteurl": null
          },
          {
            "eventType": "WordpressPlugin",
            "plugin_name": "hello",
            "plugin_status": "inactive",
            "plugin_update": "none",
            "plugin_version": "1.7",
            "siteurl": null
          },
          {
            "eventType": "WordpressUser",
            "siteurl": null,
            "user_email": "example.user@email.com",
            "user_name": "testuser1",
            "user_registered": "2018-11-26 17:44:09",
            "user_role": "administrator"
          }
        ],
        "output": [
          {
            "eventType": "WordpressSite",
            "siteurl": "http://mytest1.com"
          },
          {
            "eventType": "WordpressPlugin",
            "plugin_name": "akismet",
            "plugin_status": "inactive",
            "plugin_update": "available",
            "plugin_version": "4.0.8",
            "siteurl": "http://mytest1.com"
          },
          {
            "eventType": "WordpressPlugin",
            "plugin_name": "hello",
            "plugin_status": "inactive",
            "plugin_update": "none",
            "plugin_version": "1.7",
            "siteurl": "http://mytest1.com"
          },
          {
            "eventType": "WordpressUser",
            "siteurl": "http://mytest1.com",
            "user_email": "example.user@email.com",
            "user_name": "testuser1",
            "user_registered": "2018-11-26 17:44:09",
            "user_role": "administrator"
          }
        ]
      }
    ],
    "identifier": 53638148
  },
  {
    "context": [
      "I have below JSON file and facing error when trying to add values to array dynamically in the shell.",
      "When I try to append values to an array with a static variable, it works fine.",
      "jq '.environments.integration += [\"test1\"]' tmp.json",
      "Whereas when I try to append values dynamically, it throws an error.",
      "export Environment_Name=\"integration\"",
      "jq \".environments.\"\\\"${Environment_Name}\\\"\\\" += test1\" tmp.json",
      "You have some extra quotes in there and `test1` needs to be `[\"test1\"]`",
      "`jq \".environments.${Environment_Name} += [\\\"test1\\\"]\" tmp.json`",
      "use `env` or `--arg` or `--argjson` as appropriate, e.g.",
      "jq --arg e \"${Environment_Name}\" '.environments[$e] += [\"test1\"]'"
    ],
    "utterance": "Append the string \"test1\" to the array at the key specified by the variable Environment_Name inside the environments object.",
    "expressions": [
      "jq --arg e \"$Environment_Name\" '.environments[$e] += [\"test1\"]'",
      "jq \".environments.${Environment_Name} += [\\\"test1\\\"]\" tmp.json"
    ],
    "data": [
      {
        "input": {
          "environments": {
            "integration": [
              "testing for jenkins job"
            ],
            "prod": [],
            "staging": [],
            "uat": []
          }
        },
        "output": {
          "environments": {
            "integration": [
              "testing for jenkins job",
              "test1"
            ],
            "prod": [],
            "staging": [],
            "uat": []
          }
        }
      }
    ],
    "identifier": 53670702
  },
  {
    "context": [
      "i need the header labeled ETag but also want the json body. is there a easy way to do this...",
      "i cannot use jq because it complains about the headers, but i want the ETag header and its value too.",
      "use body_json\n    printf \"%s\\n\" \"${body_json}\" | jq",
      "jq '._links.self'  # After parse_headers is done, only the JSON should remain"
    ],
    "utterance": "Extract the value of the ETag header and the '_links.self' field from the HTTP response.",
    "expressions": [
      "printf '%s\\n' \"${body_json}\" | jq '._links.self'",
      "jq '._links.self'"
    ],
    "data": [
      {
        "input": "HTTP/1.1 200 OK\r\nContent-Type: application/vnd.go.cd.v6+json; charset=utf-8\r\nETag: \"e064ca0fe5d8a39602e19666454b8d77\"\r\n\r\n{\"_links\": {\"self\": {\"href\": \"https://ci.example.com/go/api/admin/pipelines/my_pipeline\"}}}",
        "output": {
          "ETag": "\"e064ca0fe5d8a39602e19666454b8d77\"",
          "_links.self": {
            "href": "https://ci.example.com/go/api/admin/pipelines/my_pipeline"
          }
        }
      }
    ],
    "identifier": 53635253
  },
  {
    "context": [
      "What I actually want to send to CSV here is the key Flight Delay Type (e.g. Weather Delay) and the count.",
      "How can I get that next layer down?",
      ".aggregations[].buckets[][\"3\"].buckets[] | select( .key == \"Weather Delay\")",
      ".. | select(.key? == \"Weather Delay\")",
      "yields:\n\n    {\n      \"key\": \"Weather Delay\",\n      \"doc_count\": 1\n    }"
    ],
    "utterance": "Extract all sub-bucket objects representing 'Weather Delay' under each histogram bucket, each containing the key and its doc_count.",
    "expressions": [
      ".aggregations[].buckets[][\"3\"].buckets[] | select(.key == \"Weather Delay\")",
      ".. | select(.key? == \"Weather Delay\")"
    ],
    "data": [
      {
        "input": {
          "aggregations": {
            "2": {
              "buckets": [
                {
                  "key_as_string": "2018-11-21T12:30:00.000Z",
                  "key": 1542803400000,
                  "doc_count": 2,
                  "3": {
                    "doc_count_error_upper_bound": 0,
                    "sum_other_doc_count": 0,
                    "buckets": [
                      {
                        "key": "No Delay",
                        "doc_count": 1
                      },
                      {
                        "key": "Weather Delay",
                        "doc_count": 1
                      }
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": {
          "key": "Weather Delay",
          "doc_count": 1
        }
      }
    ],
    "identifier": 53450169
  },
  {
    "context": [
      "Say, return only the records where **.fields.user_id==\"abc\"**",
      "Or, return only the records where **.fields.session_id==\"1e2d3f\"**",
      "select seems to be the way to achieve this, but I'm not sure how to express the above with it given the JSON structure above.",
      "The following produces empty result whereas it should return records for that session_id:",
      "curl -X GET ... | jq '.[] | select(.fields.session_id==\"1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14\")'",
      "This jq expression:\n\n    map(select(.fields.user_id==\"amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I\")) | length\n\nseems to work in the JQ Playground (returns the correct count of **3**):",
      "but when used on the command line, it returns a wrong result (and empty array of length **0**):",
      "As per suggestions in comments, the following query with debug returns JSON, but still doesn't produce correct counts:\n\n    $ curl ... | jq  ' debug | map(select(.fields.session_id==\"1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14\")) | length'"
    ],
    "utterance": "Return all objects from the top-level array where the fields.session_id property equals \"1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14\".",
    "expressions": [
      "map(select(.fields.session_id==\"1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14\"))",
      ".[] | select(.fields.session_id==\"1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14\")"
    ],
    "data": [
      {
        "input": [
          {
            "model": "analytics.request",
            "pk": 89,
            "fields": {
              "intent": "GetUserAccountInformation",
              "sub_intent": "",
              "request_text": "what is my balance",
              "response_text": "You have $111,111.11 and owe $111,111. Shall I break that down?",
              "session_id": "1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14",
              "user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "device_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ",
              "device_type": "alexa",
              "device_model": "NA",
              "device_os": "alexa",
              "elapsed_time": 23286,
              "region": "NA",
              "latitude": 0,
              "longitude": 0,
              "date": "2018-11-08T15:31:48.757+0000",
              "ext_session_id": "",
              "ext_user_id": "",
              "score": 1,
              "platform_type": "alexa",
              "platform_user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "platform_conversation_id": "amzn1.echo-api.session.9122211c-7fa8-43ae-b7e3-e56ebbdacc01",
              "registered": false,
              "segment_names": [
                "Seg0715080610AM",
                "customer"
              ]
            }
          },
          {
            "model": "analytics.request",
            "pk": 90,
            "fields": {
              "intent": "GetUserAccountInformation",
              "sub_intent": "",
              "request_text": "what is my balance",
              "response_text": "You have $111,111.11 and owe $111,111. Shall I break that down?",
              "session_id": "different-session",
              "user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "device_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ",
              "device_type": "alexa",
              "device_model": "NA",
              "device_os": "alexa",
              "elapsed_time": 2013,
              "region": "NA",
              "latitude": 0,
              "longitude": 0,
              "date": "2018-11-08T15:32:40.090+0000",
              "ext_session_id": "",
              "ext_user_id": "",
              "score": 1,
              "platform_type": "alexa",
              "platform_user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "platform_conversation_id": "amzn1.echo-api.session.8586bff8-21a5-4336-9c9f-1c261362b89d",
              "registered": false,
              "segment_names": [
                "Test_Segment0731174425PM",
                "Test_Segment0731172344PM"
              ]
            }
          }
        ],
        "output": [
          {
            "model": "analytics.request",
            "pk": 89,
            "fields": {
              "intent": "GetUserAccountInformation",
              "sub_intent": "",
              "request_text": "what is my balance",
              "response_text": "You have $111,111.11 and owe $111,111. Shall I break that down?",
              "session_id": "1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14",
              "user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "device_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ",
              "device_type": "alexa",
              "device_model": "NA",
              "device_os": "alexa",
              "elapsed_time": 23286,
              "region": "NA",
              "latitude": 0,
              "longitude": 0,
              "date": "2018-11-08T15:31:48.757+0000",
              "ext_session_id": "",
              "ext_user_id": "",
              "score": 1,
              "platform_type": "alexa",
              "platform_user_id": "amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I",
              "platform_conversation_id": "amzn1.echo-api.session.9122211c-7fa8-43ae-b7e3-e56ebbdacc01",
              "registered": false,
              "segment_names": [
                "Seg0715080610AM",
                "customer"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 53291061
  },
  {
    "context": [
      "I want The new `a.list` to be orig.json's list and patch.json's lists merged. In other words, I want `a.list` to equal `[\"baz\", \"bar\", \"foo\"]`.",
      "Is there a way I can easily do this with jq, perhaps by overriding the default merge strategy for arrays?",
      "def meld(a; b):\n  a as $a | b as $b\n  | if ($a|type) == \"object\" and ($b|type) == \"object\"\n    then reduce ([$a,$b]|add|keys_unsorted[]) as $k ({};\n      .[$k] = meld( $a[$k]; $b[$k]) )\n    elif ($a|type) == \"array\" and ($b|type) == \"array\"\n    then $a+$b\n    elif $b == null then $a\n    else $b\n    end;",
      "jq -s 'def deepmerge(a;b):\n  reduce b[] as $item (a;\n    reduce ($item | keys_unsorted[]) as $key (.;\n      $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == \"object\") then\n        deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val])\n      elif ($type == \"array\") then\n        (.[$key] + $val | unique)\n      else\n        $val\n      end)\n    );\n  deepmerge({}; .)' file1.json file2.json > merged.json",
      "(.a.list + $patch.a.list) as $a\n| . + $patch\n| .a.list = $a"
    ],
    "utterance": "Recursively merge two objects such that arrays with the same key are concatenated instead of replaced.",
    "expressions": [
      "def meld(a; b): a as $a | b as $b | if ($a|type) == \"object\" and ($b|type) == \"object\" then reduce ([$a,$b]|add|keys_unsorted[]) as $k ({}; .[$k] = meld( $a[$k]; $b[$k]) ) elif ($a|type) == \"array\" and ($b|type) == \"array\" then $a+$b elif $b == null then $a else $b end; meld($orig; $patch)",
      "jq -s 'def deepmerge(a;b): reduce b[] as $item (a; reduce ($item | keys_unsorted[]) as $key (.; $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == \"object\") then deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val]) elif ($type == \"array\") then (.[$key] + $val | unique) else $val end)); deepmerge({}; .)' file1.json file2.json > merged.json",
      "(.a.list + $patch.a.list) as $a | . + $patch | .a.list = $a"
    ],
    "data": [
      {
        "input": {
          "orig": {
            "a": {
              "a1": "original a1",
              "a2": "original a2",
              "list": [
                "baz",
                "bar"
              ]
            },
            "b": "original value B"
          },
          "patch": {
            "a": {
              "a1": "patch a1",
              "list": [
                "foo"
              ]
            },
            "c": "original c"
          }
        },
        "output": {
          "a": {
            "a1": "patch a1",
            "a2": "original a2",
            "list": [
              "baz",
              "bar",
              "foo"
            ]
          },
          "b": "original value B",
          "c": "original c"
        }
      }
    ],
    "identifier": 53661930
  },
  {
    "context": [
      "What I am looking for is a command to output each code separated by a newline so like this:\r\n\r\n    Z00A000\r\n    Z00A020\r\n    Z01A102\r\n    Z01C027\r\n    X00P002\r\n    X00T027\r\n    X01A003\r\n    X01A020\r\n\r\nThe format of the JSON will always be the same though the names \"Z\" and \"X\" and the sub names \"00\" \"01\" etc are liable to change so they cannot be hard coded.",
      "Here is a solution that is based on the uniformity of the format.  \r\n\r\nFirst, let's define a helper function that handles JSON objects whose values are arrays of objects of the form `{\"e\": _}`:\r\n\r\n    def combine:\r\n      keys_unsorted[] as $k\r\n      | $k + (.[$k][]|.e) ;\r\n\r\nNow the solution can be written in just two lines:\r\n \r\n    keys_unsorted[] as $k\r\n    | $k + (.[$k]|combine)\r\n\r\nUsing the -r command-line option will cause the strings to be emitted without enclosing quotation marks.",
      "The following is not only much more general but also illustrates a different strategy that opens up further generalizations and variants:\r\n\r\n    paths as $p\r\n    | getpath($p) as $v\r\n    | select($v | type == \"string\")\r\n    | $p\r\n    | map(select(type==\"string\"))\r\n    | map(select(. != \"e\"))\r\n    | . + [$v]\r\n    | join(\"\")"
    ],
    "utterance": "Print each code by joining the top-level key, the second-level key, and each object's 'e' value, with each result on a new line, without hard-coding any key names.",
    "expressions": [
      "def combine: keys_unsorted[] as $k | $k + (.[$k][]|.e) ; keys_unsorted[] as $k | $k + (.[$k]|combine)",
      "paths as $p | getpath($p) as $v | select($v | type == \"string\") | $p | map(select(type==\"string\")) | map(select(. != \"e\")) | . + [$v] | join(\"\")"
    ],
    "data": [
      {
        "input": {
          "Z": {
            "00": [
              {
                "e": "A000"
              },
              {
                "e": "A020"
              }
            ],
            "01": [
              {
                "e": "A102"
              },
              {
                "e": "C027"
              }
            ]
          },
          "X": {
            "00": [
              {
                "e": "P002"
              },
              {
                "e": "T027"
              }
            ],
            "01": [
              {
                "e": "A003"
              },
              {
                "e": "A020"
              }
            ]
          }
        },
        "output": [
          "Z00A000",
          "Z00A020",
          "Z01A102",
          "Z01C027",
          "X00P002",
          "X00T027",
          "X01A003",
          "X01A020"
        ]
      }
    ],
    "identifier": 53643808
  },
  {
    "context": [
      "Is it possible to use `jq` to turn the following JSON data ... into ...? Note that the purpose is to reduce the `b` list with certain elements of its items based on a condition. The condition assigns the string `d1` if the value of `d` is `dd1`, otherwise `d2` is assigned if `dd2` is present.",
      "jq '[].b |= map(\n   [ .c,\n     (if .d == \"dd1\" then \"d1\" elif .d == \"dd2\" then \"d2\" else . end),\n     .f // empty\n   ] )'"
    ],
    "utterance": "Transform each object so that the list at key b is mapped to arrays containing the value of c, a new value \"d1\" if d is \"dd1\" or \"d2\" if d is \"dd2\", and, if it exists, the value of f.",
    "expressions": [
      "map(.b |= map([ .c, (if .d == \"dd1\" then \"d1\" elif .d == \"dd2\" then \"d2\" else . end), .f // empty ]))",
      ".[].b |= map([ .c, (if .d == \"dd1\" then \"d1\" elif .d == \"dd2\" then \"d2\" else . end), .f // empty ])"
    ],
    "data": [
      {
        "input": [
          {
            "a": null,
            "b": [
              {
                "c": "cc",
                "d": "dd1"
              },
              {
                "c": "cc",
                "d": "dd1",
                "e": "ee",
                "f": "ff"
              }
            ]
          },
          {
            "b": [
              {
                "c": "cc",
                "d": "dd2",
                "e": "ee",
                "f": "ff"
              }
            ]
          }
        ],
        "output": [
          {
            "a": null,
            "b": [
              [
                "cc",
                "d1"
              ],
              [
                "cc",
                "d1",
                "ff"
              ]
            ]
          },
          {
            "b": [
              [
                "cc",
                "d2",
                "ff"
              ]
            ]
          }
        ]
      }
    ],
    "identifier": 53250318
  },
  {
    "context": [
      "Filter: `.[]|=empty`",
      "Input: `[0,1,2,3,4,5]`",
      "Output: [ 1, 3, 5 ]",
      "Apparently, only even array indexes are deleted. Why?"
    ],
    "utterance": "Remove every element from the array using the update-assignment operator with empty.",
    "expressions": [
      ".[] |= empty"
    ],
    "data": [
      {
        "input": [
          0,
          1,
          2,
          3,
          4,
          5
        ],
        "output": [
          1,
          3,
          5
        ]
      }
    ],
    "identifier": 53381867
  },
  {
    "context": [
      "How can I parse one of the JSON objects by the timestamp with a shell variable?",
      "You need to use the full syntax for key access, as the dollar sign preclude you using the shorter form.",
      "try .[\"field\"] instead of .field for unusually named fields",
      "$ jq --arg date 1543359600 '.[$date]' tmp.json",
      "{\n  \"name\": \"Kate\",\n  \"company\": \"bar\"\n}"
    ],
    "utterance": "Retrieve the object associated with a specified timestamp key, where the timestamp is provided as a shell variable.",
    "expressions": [
      ".[$date]"
    ],
    "data": [
      {
        "input": {
          "1543446000": {
            "name": "John",
            "company": "foo"
          },
          "1543359600": {
            "name": "Kate",
            "company": "bar"
          }
        },
        "output": {
          "name": "Kate",
          "company": "bar"
        }
      }
    ],
    "identifier": 53547982
  }
]