[
  {
    "context": [
      "My question is how do I get bar and baz associated with their name and role?  Where the output would be:",
      "    bar,bob,gopherthis",
      "    baz,tom,gopherthat",
      "jq -r '.foo | to_entries[] | \"\\(.key),\\(.value.name),\\(.value.role)\"' example.json",
      "The output:",
      "    bar,bob,gopherthis",
      "    baz,tom,gopherthat"
    ],
    "utterance": "List each object under 'foo' with its key, name, and role as comma-separated values.",
    "expressions": [
      ".foo | to_entries[] | \"\\(.key),\\(.value.name),\\(.value.role)\""
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": {
              "name": "bob",
              "role": "gopherthis"
            },
            "baz": {
              "name": "tom",
              "role": "gopherthat"
            }
          }
        },
        "output": [
          "bar,bob,gopherthis",
          "baz,tom,gopherthat"
        ]
      }
    ],
    "identifier": 49240873
  },
  {
    "context": [
      "for option in \"header\" \"developer\" \"category\" \"description\"\n      do\n        content=$(curl -s $extension_url | jq \".[\\\"$extension\\\"][\\\"$option\\\"]\")\n        printf \"$content\\n\"\n      done",
      "is there just a better solution ... ?",
      "you can avoid calling jq more than once by simply using jq's ',', operator.",
      "curl -s \"$extension_url\" |\n  jq --arg extension \"$extension\" '\n    .[$extension][\"header\",\"developer\",\"category\",\"description\"]'\n"
    ],
    "utterance": "Extract the values of the keys \"header\", \"developer\", \"category\", and \"description\" for the given extension variable from the top-level object at the given URL.",
    "expressions": [
      "jq --arg extension \"$extension\" '.[$extension][\"header\",\"developer\",\"category\",\"description\"]'"
    ],
    "identifier": 49247989
  },
  {
    "context": [
      "I want to convert these json into csv like below.",
      "jq -r '[.[]] | @csv' palanikumar.json",
      "With the given input, this produces the following CSV:",
      "\"ca\",812,404,130756,\"hit\"",
      "\"ua\",206996,301,142,\"unknown\"",
      "\"ua\",206996,0,0,\"unknown\"",
      "Adding the headers and the trailing semicolons (if you really want them) is left as a (very easy) exercise.",
      "If the ordering of the keys varies or might vary, then the following could be used to produce suitable CSV, assuming that the ordering of the keys in the first object in the input stream should be used:",
      "input | . as $first | keys_unsorted as $keys | $keys, [$first[]], (inputs | [.[$keys[]]]) | @csv"
    ],
    "utterance": "Convert a list of key-value objects to CSV rows with values ordered as in the keys, optionally including a header row.",
    "expressions": [
      "[.[]] | @csv",
      ". as $first | keys_unsorted as $keys | $keys, [$first[]], (inputs | [.[$keys[]]]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "ClientCountry": "ca",
            "ClientASN": 812,
            "CacheResponseStatus": 404,
            "CacheResponseBytes": 130756,
            "CacheCacheStatus": "hit"
          },
          {
            "ClientCountry": "ua",
            "ClientASN": 206996,
            "CacheResponseStatus": 301,
            "CacheResponseBytes": 142,
            "CacheCacheStatus": "unknown"
          },
          {
            "ClientCountry": "ua",
            "ClientASN": 206996,
            "CacheResponseStatus": 0,
            "CacheResponseBytes": 0,
            "CacheCacheStatus": "unknown"
          }
        ],
        "output": [
          "\"ca\",812,404,130756,\"hit\"",
          "\"ua\",206996,301,142,\"unknown\"",
          "\"ua\",206996,0,0,\"unknown\""
        ]
      }
    ],
    "identifier": 49228126
  },
  {
    "context": [
      "I am trying to write into a csv file keys and values that are in a kafka topic. I have been able to select the keys and values that I want, but I am not able to get them separated by rows (three values per row values in rows separated by commas).",
      "I tried using this command, but each value is being put into its own row:\n\n`./kafka-run-class.sh kafka.tools.ConsoleConsumer --bootstrap-server kafka1.example.net:9092 --topic prod.example.v1 --max-messages 3 | jq -r ' .isBusiness, .countryCode, .phone ' > file.csv`\n\nIdeal output would be:\n\n    false, MX, 52/4446789864\n    false, GB, 44/0187567846\n    true, BE, 32/8745687645",
      "jq -r '[.isBusiness, .countryCode, .phone] | @csv'",
      "The filter:\n\n    \"\\(.isBusiness), \\(.countryCode), \\(.phone)\""
    ],
    "utterance": "Output isBusiness, countryCode, and phone fields with each record on its own line as a comma-separated row.",
    "expressions": [
      "[.isBusiness, .countryCode, .phone] | @csv",
      "\"\\(.isBusiness), \\(.countryCode), \\(.phone)\""
    ],
    "data": [
      {
        "input": {
          "count": "0",
          "source": 3,
          "lastModified": "2018-03-09T21:03:54.039Z",
          "isBusiness": false,
          "countryCode": " MX",
          "phone": "52/4446789864"
        },
        "output": "false, MX, 52/4446789864"
      },
      {
        "input": {
          "count": "0",
          "source": 3,
          "lastModified": "2018-03-09T21:03:54.039Z",
          "isBusiness": false,
          "countryCode": " GB",
          "phone": "44/0187567846"
        },
        "output": "false, GB, 44/0187567846"
      }
    ],
    "identifier": 49202920
  },
  {
    "context": [
      "How do I show only results where subver does not contain  \"0.22.5.7\" OR .synced_blocks < 77982 ?",
      "select( ( .subver | test(\"(^|:)0.22.5.7($|/)\") | not) or\n        .synced_blocks < 77982)"
    ],
    "utterance": "Show objects where the subver field does not contain '0.22.5.7' or synced_blocks is less than 77982.",
    "expressions": [
      ".[] | select((.subver | test(\"(^|:)0.22.5.7($|/)\") | not) or (.synced_blocks < 77982))"
    ],
    "data": [
      {
        "input": [
          {
            "addr": "299.247.7.254:8268",
            "subver": "/String:0.22.5.7/",
            "inbound": false,
            "synced_blocks": 77979
          },
          {
            "addr": "228.290.206.224:8268",
            "subver": "/String:0.22.5.6/",
            "inbound": false,
            "synced_blocks": 77980
          },
          {
            "addr": "208.62.262.244:55226",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77978
          },
          {
            "addr": "200.2.222.25:50452",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77980
          },
          {
            "addr": "220.92.79.44:50970",
            "subver": "/String:0.22.4.2/",
            "inbound": true,
            "synced_blocks": -2
          },
          {
            "addr": "45.22.228.69:57462",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77980
          },
          {
            "addr": "29.206.256.229:8268",
            "subver": "/String:0.22.5.7/",
            "inbound": false,
            "synced_blocks": 77980
          }
        ],
        "output": [
          {
            "addr": "299.247.7.254:8268",
            "subver": "/String:0.22.5.7/",
            "inbound": false,
            "synced_blocks": 77979
          },
          {
            "addr": "228.290.206.224:8268",
            "subver": "/String:0.22.5.6/",
            "inbound": false,
            "synced_blocks": 77980
          },
          {
            "addr": "208.62.262.244:55226",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77978
          },
          {
            "addr": "200.2.222.25:50452",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77980
          },
          {
            "addr": "220.92.79.44:50970",
            "subver": "/String:0.22.4.2/",
            "inbound": true,
            "synced_blocks": -2
          },
          {
            "addr": "45.22.228.69:57462",
            "subver": "/String:0.22.5.7/",
            "inbound": true,
            "synced_blocks": 77980
          },
          {
            "addr": "29.206.256.229:8268",
            "subver": "/String:0.22.5.7/",
            "inbound": false,
            "synced_blocks": 77980
          }
        ]
      }
    ],
    "identifier": 49225840
  },
  {
    "context": [
      "just need to combine 2nd and 3rd into single one",
      "Tried `(.RolePolicyList[].PolicyName + \" \" + .AttachedManagedPolicies[].PolicyName)` but then getting `\"ADFS-Administrators\",\"arn:aws:iam::279052847476:saml-provider/CompanyADFS\"`",
      "needed to wrap it into array and to apply join",
      "jq -rc '.RoleDetailList\n    | map(select((.AssumeRolePolicyDocument.Statement | length > 0) and \n        (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \n        (.AttachedManagedPolicies | length >0) or \n        (.RolePolicyList | length > 0)) )[]\n    | [.RoleName,\n       ([.RolePolicyList[].PolicyName,\n         ([.AttachedManagedPolicies[].PolicyName] | join(\"--\"))] \n        | join(\" \")),\n       (.AssumeRolePolicyDocument.Statement[] | .Principal.Federated)] \n    | @csv' output.json"
    ],
    "utterance": "Output a CSV with each line containing the role name, a single column combining all RolePolicyList PolicyNames and all AttachedManagedPolicies PolicyNames (joined by space or separator), and the Principal Federated value.",
    "expressions": [
      ".RoleDetailList\n| map(select((.AssumeRolePolicyDocument.Statement | length > 0) and \n    (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \n    (.AttachedManagedPolicies | length >0) or \n    (.RolePolicyList | length > 0)) )[]\n| [.RoleName,\n   ([.RolePolicyList[].PolicyName,\n     ([.AttachedManagedPolicies[].PolicyName] | join(\"--\"))] \n    | join(\" \")),\n   (.AssumeRolePolicyDocument.Statement[] | .Principal.Federated)] \n| @csv"
    ],
    "identifier": 49273348
  },
  {
    "context": [
      "How,for all these sections in JSON file to get following (this is example for this section only) to CSV format ?",
      "@Roman, your solution works, how to add another column, to get Policy Name from\n\n    \"AttachedManagedPolicies\": [\n                    {\n                        \"PolicyName\": \"pol-amtest-ro\", \n                        \"PolicyArn\": \"arn:aws:iam::279052847476:policy/pol-amtest-ro\"\n                    }\n                ],",
      "jq -r '.RoleDetailList \n           | map(select((.AssumeRolePolicyDocument.Statement | length > 0) \n                         and (.AssumeRolePolicyDocument.Statement[0].Principal.Federated) \n                         and (.RolePolicyList | length > 0))\n             )[] \n           | [(.AssumeRolePolicyDocument.Statement[0] | .Action, .Principal.Federated),\n               .RoleName, .RolePolicyList[0].PolicyName] | @csv' output.json",
      "The output:\n\n    \"sts:AssumeRoleWithSAML\",\"arn:aws:iam::279052847476:saml-provider/companyADFS\",\"ADFS-Administrators\",\"Administrator-Access\""
    ],
    "utterance": "Extract, for each role, the first AssumeRolePolicyDocument Statement Action, Principal Federated, RoleName, first RolePolicyList PolicyName, and output them in CSV format.",
    "expressions": [
      ".RoleDetailList\n| map(select((.AssumeRolePolicyDocument.Statement | length > 0) \n             and (.AssumeRolePolicyDocument.Statement[0].Principal.Federated) \n             and (.RolePolicyList | length > 0)))[]\n| [(.AssumeRolePolicyDocument.Statement[0] | .Action, .Principal.Federated), .RoleName, .RolePolicyList[0].PolicyName] | @csv"
    ],
    "data": [
      {
        "input": {
          "RoleDetailList": [
            {
              "AssumeRolePolicyDocument": {
                "Version": "2012-10-17",
                "Statement": [
                  {
                    "Action": "sts:AssumeRoleWithSAML",
                    "Effect": "Allow",
                    "Condition": {
                      "StringEquals": {
                        "SAML:aud": "https://signin.aws.amazon.com/saml"
                      }
                    },
                    "Principal": {
                      "Federated": "arn:aws:iam::279052847476:saml-provider/companyADFS"
                    }
                  }
                ]
              },
              "RoleId": "AROAJANL3L2IZ6UISEGAU",
              "CreateDate": "2016-08-20T13:51:07Z",
              "InstanceProfileList": [],
              "RoleName": "ADFS-Administrators",
              "Path": "/",
              "AttachedManagedPolicies": [],
              "RolePolicyList": [
                {
                  "PolicyName": "Administrator-Access",
                  "PolicyDocument": {
                    "Version": "2012-10-17",
                    "Statement": [
                      {
                        "Action": "*",
                        "Resource": "*",
                        "Effect": "Allow",
                        "Sid": "Stmt1434192117145"
                      }
                    ]
                  }
                }
              ],
              "Arn": "arn:aws:iam::279052847476:role/ADFS-Administrators"
            }
          ]
        },
        "output": "\"sts:AssumeRoleWithSAML\",\"arn:aws:iam::279052847476:saml-provider/companyADFS\",\"ADFS-Administrators\",\"Administrator-Access\""
      }
    ],
    "identifier": 49253032
  },
  {
    "context": [
      "Input:",
      "{\n  \"Object1\": {\n    \"id\": 1,\n    \"name\": \"object1name\"\n  },\n  \"Object2\": {\n    \"id\": 24,\n    \"name\": \"object2name\"\n  }\n}",
      "Expected output:",
      "{\n  \"object1name\":1,\n  \"object2name\":2 \n}",
      "I tried the following jq code but it gives me an error:\n{.[] | ((.name):.id)}",
      "Collect the objects in an array and reduce it with `add`:\n\n    $ jq '[.[] | {(.name): .id}] | add' tmp.json\n    {\n      \"object1name\": 1,\n      \"object2name\": 24\n    }",
      "You can write the filter a little more tersely as `map({(.name): .id}) | add`.",
      "[ {(.[] | .name): .id}] | add"
    ],
    "utterance": "Build a lookup table mapping each object's 'name' to its 'id' from nested objects.",
    "expressions": [
      "[.[] | {(.name): .id}] | add",
      "map({(.name): .id}) | add",
      "[ {(.[] | .name): .id}] | add"
    ],
    "data": [
      {
        "input": {
          "Object1": {
            "id": 1,
            "name": "object1name"
          },
          "Object2": {
            "id": 24,
            "name": "object2name"
          }
        },
        "output": {
          "object1name": 1,
          "object2name": 24
        }
      }
    ],
    "identifier": 49284942
  },
  {
    "context": [
      "The desired output would be `2018-03-13 14:00:17`",
      "if you know your format won't change, there's no particular reason to use `strptime` or `strftime` at all:\n\n    jq -r '.time_field | sub(\"^(?<date>[[:digit:]-]+)T(?<time>[[:digit:]:]+)[.].*\";\n                             \"\\(.date) \\(.time)\")' \\\n      <<<'{\"time_field\": \"2018-03-13T14:00:17.1614661Z\"}'\n\n...properly emits:\n\n    2018-03-13 14:00:17",
      "So I found a workaround to get around the ZULU offset and the nano-seconds since I do not really care so much about the nano-seconds. Not sure if it is efficient\n\necho '{\"time_field\": \"2018-03-13T14:00:17.1234567Z\"}' | jq -r '\n    .time_field \n    | split(\".\")[0] \n    | strptime(\"%Y-%m-%dT%H:%M:%S\") \n    | mktime \n    | strftime(\"%F %X\")'"
    ],
    "utterance": "Extract the date and time up to seconds from an ISO8601 string containing nanoseconds and a trailing Z, producing output in 'YYYY-MM-DD HH:MM:SS' format.",
    "expressions": [
      ".time_field | sub(\"^(?<date>[[:digit:]-]+)T(?<time>[[:digit:]:]+)[.].*\"; \"\\(.date) \\(.time)\")",
      ".time_field | split(\".\")[0] | strptime(\"%Y-%m-%dT%H:%M:%S\") | mktime | strftime(\"%F %X\")"
    ],
    "data": [
      {
        "input": {
          "time_field": "2018-03-13T14:00:17.1614661Z"
        },
        "output": "2018-03-13 14:00:17"
      },
      {
        "input": {
          "time_field": "2018-03-13T14:00:17.1234567Z"
        },
        "output": "2018-03-13 14:00:17"
      }
    ],
    "identifier": 49262889
  },
  {
    "context": [
      "How to get following output (map IAM role to policy) and convert it to csv file using jq  ?",
      "Desired output:",
      "AWSCorpAdmin,AdministratorAccess ",
      "I need to loop throuhg whole JSON file and to get policy for every role (above is just example)",
      "jq -r '.RoleDetailList | map(select(.AttachedManagedPolicies | length > 0))[] \n       | .RoleName as $r | .AttachedManagedPolicies[] \n       | [$r, .PolicyName] | @csv' output.json",
      "Sample output:",
      "\"ADFS-amtest-ro\",\"pol-amtest-ro\"",
      "\"AWSAccCorpAdmin\",\"AdministratorAccess\""
    ],
    "utterance": "Extract all pairs of role name and attached managed policy name from each section and output them in CSV format using a single query.",
    "expressions": [
      ".RoleDetailList | map(select(.AttachedManagedPolicies | length > 0))[] | .RoleName as $r | .AttachedManagedPolicies[] | [$r, .PolicyName] | @csv"
    ],
    "data": [
      {
        "input": {
          "RoleDetailList": [
            {
              "RoleName": "AWSCorpAdmin",
              "AttachedManagedPolicies": [
                {
                  "PolicyName": "AdministratorAccess",
                  "PolicyArn": "arn:aws:iam::aws:policy/AdministratorAccess"
                }
              ]
            },
            {
              "RoleName": "MyOtherRole",
              "AttachedManagedPolicies": []
            }
          ]
        },
        "output": "\"AWSCorpAdmin\",\"AdministratorAccess\""
      }
    ],
    "identifier": 49238602
  },
  {
    "context": [
      "Clarification: I need to extract name and parent_id, sorted by parent_id, when it is not null.",
      "jq's sort_by() function accepts an array as input.",
      "curl 'http://...' |\n    jq -r '\n        map(select(.parent_id != null)) \n        | sort_by(.parent_id)[]\n        | [.name, .parent_id]\n        | @tsv\n    '",
      "Sample output:\n\n    asdfg\t7\n    another-test\t9"
    ],
    "utterance": "Extract the name and parent_id fields for objects where parent_id is not null, and output them sorted by parent_id.",
    "expressions": [
      "map(select(.parent_id != null)) | sort_by(.parent_id)[] | [.name, .parent_id] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 10,
            "name": "another-test",
            "path": "another-test",
            "description": "",
            "visibility": "private",
            "lfs_enabled": true,
            "avatar_url": null,
            "web_url": "https://mygitlab/groups/another-test",
            "request_access_enabled": false,
            "full_name": "another-test",
            "full_path": "another-test",
            "parent_id": 9
          },
          {
            "id": 11,
            "name": "asdfg",
            "path": "asdfg",
            "description": "",
            "visibility": "private",
            "lfs_enabled": true,
            "avatar_url": null,
            "web_url": "https://mygitlab/groups/asdfg",
            "request_access_enabled": false,
            "full_name": "asdfg",
            "full_path": "asdfg",
            "parent_id": 7
          }
        ],
        "output": "asdfg\t7\nanother-test\t9"
      }
    ],
    "identifier": 49200066
  },
  {
    "context": [
      "Using `jq`, I would like to get all the children of the root element and include their keys.",
      "e.g. from this document:\r\n\r\n    {\"foo\": [1, 2, 3], \"bar\": [4, 5, 6]}\r\n\r\nI would like to get:\r\n\r\n    {\"foo\": [1, 2, 3]}\r\n    {\"bar\": [4, 5, 6]}",
      "Using variations on array indexing, I lose the keys:",
      "One way:\r\n\r\n    to_entries[] | [.] | from_entries",
      "More prosaically:\r\n\r\n    keys_unsorted[] as $k | {($k): .[$k]}"
    ],
    "utterance": "For each key-value pair at the root level, produce an object containing just that key and its value.",
    "expressions": [
      "to_entries[] | [.] | from_entries",
      "keys_unsorted[] as $k | {($k): .[$k]}"
    ],
    "data": [
      {
        "input": {
          "foo": [
            1,
            2,
            3
          ],
          "bar": [
            4,
            5,
            6
          ]
        },
        "output": [
          {
            "foo": [
              1,
              2,
              3
            ]
          },
          {
            "bar": [
              4,
              5,
              6
            ]
          }
        ]
      }
    ],
    "identifier": 49289408
  },
  {
    "context": [
      "I want to get the result in the form of an array. Is it possible to get the multiple result values of select operation in an array?",
      "Yes; wrap the filter in an array :)",
      "$ jq '[.[] | select(.id == \"second\")]' tmp.json",
      "Or, use `map/1`, which is predefined as `[.[] | ...]`.",
      "$ jq 'map(select(.id == \"second\"))' tmp.json"
    ],
    "utterance": "Select all objects where id equals \"second\" and output the results as an array.",
    "expressions": [
      "[.[] | select(.id == \"second\")]",
      "map(select(.id == \"second\"))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "first",
            "val": 1
          },
          {
            "id": "second",
            "val": 2
          },
          {
            "id": "second",
            "val": 3
          }
        ],
        "output": [
          {
            "id": "second",
            "val": 2
          },
          {
            "id": "second",
            "val": 3
          }
        ]
      }
    ],
    "identifier": 49302617
  },
  {
    "context": [
      "Here is the full response stored in a variable (did the same for the github examples from `jq` tutorial):",
      "{ \"matches\": [ { \"threatType\": \"MALWARE\", \"platformType\": \"ALL_PLATFORMS\", \"threat\": { \"url\": \"http://www.wittyvideos.com\" }, \"cacheDuration\": \"300s\", \"threatEntryType\": \"URL\" } ] }",
      "echo \"$safeb\" | jq '.matches.threatType'",
      "jq: error (at <stdin>:13): Cannot index array with string \"threatType\"",
      "echo \"$safeb\" | jq '.threatType'",
      "null",
      "echo \"$safeb\" | jq '.[] | .threatType'",
      "jq: error (at <stdin>:13): Cannot index array with string \"threatType\"",
      "Answer: .matches is an array, so you'd have to use [] to expand it, e.g.:",
      ".matches[].threatType",
      "You probably meant:",
      ".matches[] | {type: .threatType}"
    ],
    "utterance": "Extract all threatType values from the matches array in the response.",
    "expressions": [
      ".matches[].threatType",
      ".matches[] | {type: .threatType}"
    ],
    "data": [
      {
        "input": {
          "matches": [
            {
              "threatType": "MALWARE",
              "platformType": "ALL_PLATFORMS",
              "threat": {
                "url": "http://www.wittyvideos.com"
              },
              "cacheDuration": "300s",
              "threatEntryType": "URL"
            }
          ]
        },
        "output": [
          "MALWARE"
        ]
      }
    ],
    "identifier": 49299086
  },
  {
    "context": [
      "I have a JSON array <i>**conf=**</i> \r\n\r\n     [ { \"fraudThreshold\": 4, \"fraudTTLSec\": 60 }, { \"fraudThreshold\": 44, \"fraudTTLSec\": 60 } ]",
      "In order to loop through the items in the JSON array using bash, you could write:",
      "    echo \"${conf}\" | jq -cr \".[]\" |",
      "    while read -r configy",
      "    do",
      "      echo configy=\"$configy\"",
      "    done",
      "echo \"${conf}\" | jq -car '.[] | \"configy=\" + tojson'"
    ],
    "utterance": "Retrieve each object in the array as a compact JSON string, one per line.",
    "expressions": [
      ".[]",
      "-c .[]",
      ".[] | \"configy=\" + tojson"
    ],
    "data": [
      {
        "input": [
          {
            "fraudThreshold": 4,
            "fraudTTLSec": 60
          },
          {
            "fraudThreshold": 44,
            "fraudTTLSec": 60
          }
        ],
        "output": [
          {
            "fraudThreshold": 4,
            "fraudTTLSec": 60
          },
          {
            "fraudThreshold": 44,
            "fraudTTLSec": 60
          }
        ]
      }
    ],
    "identifier": 49312431
  },
  {
    "context": [
      "- `.commit.author.date&gt;=2016`, and",
      "- `.commit.comment_count&gt;=1`",
      "map(select(.commit | (.author.date[:4] | tonumber) &gt;= 2016 and .comment_count &gt;= 1))",
      "map(select((.commit.author.date[:4] | tonumber) &gt;= 2016 and .commit.comment_count &gt;= 1))"
    ],
    "utterance": "Filter an array to include only those items where the commit author's date is in 2016 or later and the commit comment_count is at least 1.",
    "expressions": [
      "map(select(.commit | (.author.date[:4] | tonumber) >= 2016 and .comment_count >= 1))",
      "map(select((.commit.author.date[:4] | tonumber) >= 2016 and .commit.comment_count >= 1))"
    ],
    "identifier": 49353318
  },
  {
    "context": [
      "How to wrap the whole return into a json structure of:\r\n\r\n    { \"Commits\": [ {...}, {...}, {...} ] }",
      "To produce a JSON object of the form: \r\n\r\n    { \"Commits\": [ {...}, {...}, {...} ] }\r\n\nyou could write something like:\r\n\r\n    jq '{Commits: [.[] | {message: .commit.message, name: .commit.committer.name}]}'",
      "jq understands the '{Commits: _}' shorthand."
    ],
    "utterance": "Wrap the results of extracting message and committer name from all commit objects in a top-level object with a Commits array property.",
    "expressions": [
      "{Commits: [.[] | {message: .commit.message, name: .commit.committer.name}]}"
    ],
    "data": [
      {
        "input": [
          {
            "commit": {
              "message": "hi",
              "committer": {
                "name": "A"
              }
            }
          },
          {
            "commit": {
              "message": "hello",
              "committer": {
                "name": "B"
              }
            }
          }
        ],
        "output": {
          "Commits": [
            {
              "message": "hi",
              "name": "A"
            },
            {
              "message": "hello",
              "name": "B"
            }
          ]
        }
      }
    ],
    "identifier": 49342129
  },
  {
    "context": [
      "with this one-liner `IFS=_ read -r -a a < <(jq -ncj '[\"a\",\"b\",\"c\"][]+\"_\"') ; printf '%s\\n' \"${a[@]}\"` I get a properly delimited output",
      "BUT if I try the same thing with a null delimiter like so: `IFS= read -r -a a < <(jq -ncj '[\"a\",\"b\",\"c\"][]+\"\\u0000\"') ; printf '%s\\n' \"${a[@]}\"` then I would get only one array element containing\n> abc",
      "Furthermore, if you try `IFS= read -r -d '' -a a < <(jq -ncj '[\"a\",\"b\",\"c\"][]+\"\\u0000\"') ; printf '%s\\n' \"${a[@]}`, you will be surprised to get an array with only the first \"<b>a</b>\" element:\n> a",
      "a=()\nwhile read -d '' -r item; do\n    a+=(\"$item\")\ndone < <( jq -ncj '[\"a\",\"b\",\"c\"][]+\"\\u0000\"' )"
    ],
    "utterance": "Produce a stream where each element from the list [\"a\",\"b\",\"c\"] is output followed by a null character delimiter.",
    "expressions": [
      "[\"a\",\"b\",\"c\"][] + \"\\u0000\""
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": "a\u0000b\u0000c\u0000"
      }
    ],
    "identifier": 49321015
  },
  {
    "context": [
      "I want to replace the date with timestamp.",
      "I can make this conversion with date in the shell",
      "Is it possible to execute the date conversion with jq or another command like awk, sed, perl in a single command line?",
      "Here is an all-jq solution that assumes the \"Z\" (UTC+0) timezone.",
      "simply replace `.T` by: ((.T + \"Z\") | fromdate | tostring + \"000\")",
      "[splits(\"[(),]\")] | .[1] |= ((. + \"Z\")|fromdate|tostring + \"000\")  # milliseconds | .[1:length-1] | \"(\" + join(\",\") + \")\""
    ],
    "utterance": "Replace the date string at the first position of each tuple with the corresponding UTC timestamp in milliseconds.",
    "expressions": [
      "((.T + \"Z\") | fromdate | tostring + \"000\")",
      "[splits(\"[(),]\")] | .[1] |= ((. + \"Z\")|fromdate|tostring + \"000\") | .[1:length-1] | \"(\" + join(\",\") + \")\""
    ],
    "data": [
      {
        "input": [
          "(2018-03-17T18:30:00,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)",
          "(2018-03-17T19:00:00,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)"
        ],
        "output": [
          "(1521325800000,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)",
          "(1521327600000,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)"
        ]
      }
    ],
    "identifier": 49343797
  },
  {
    "context": [
      "I am looking to use jq to extract certain fields and convert to csv. My expected output would look something like:",
      "\"CVE-2018-0802\",\"CVE\"",
      "\"tibetnews.today\",\"domain\"",
      "\"02281e26e89b61d84e2df66a0eeb729c5babd94607b1422505cd388843dd5456\",\"FileHash-SHA256\"",
      ".results is an array so you'll have to expand it too. This can be done either by:",
      ".results[] | .indicators[] | [.indicator, .type] | @csv",
      "or more compactly:",
      ".results[].indicators[] | [.indicator, .type] | @csv",
      "Output",
      "\"CVE-2018-0802\",\"CVE\"",
      "\"fb9c9cbf6925de8c7b6ce8e7a8d5290e628be0b82a58f3e968426c0f734f38f6\",\"FileHash-SHA256\""
    ],
    "utterance": "Extract each indicator and its type from the indicators of all results and output them as CSV rows.",
    "expressions": [
      ".results[] | .indicators[] | [.indicator, .type] | @csv",
      ".results[].indicators[] | [.indicator, .type] | @csv"
    ],
    "data": [
      {
        "input": {
          "count": 1210,
          "next": "https://otx.alienvault.com/api/v1/pulses/subscribed?page=2",
          "results": [
            {
              "industries": [],
              "tlp": "white",
              "description": "Tropic Trooper (also known as KeyBoy) levels its campaigns against Taiwanese, Philippine, and Hong Kong targets, focusing on their government, healthcare, transportation, and high-tech industries. Its operators are believed to be very organized and develop their own cyberespionage tools that they fine-tuned in their recent campaigns. Many of the tools they use now feature new behaviors, including a change in the way they maintain a foothold in the targeted network.",
              "created": "2018-03-14T17:24:48.014000",
              "tags": [
                "china",
                "keyboy",
                "tropic trooper"
              ],
              "modified": "2018-03-14T17:24:48.014000",
              "author_name": "AlienVault",
              "public": 1,
              "extract_source": [],
              "references": [
                "https://blog.trendmicro.com/trendlabs-security-intelligence/tropic-trooper-new-strategy/"
              ],
              "targeted_countries": [],
              "indicators": [
                {
                  "indicator": "CVE-2018-0802",
                  "description": "",
                  "created": "2018-03-14T17:25:03",
                  "title": "",
                  "content": "",
                  "type": "CVE",
                  "id": 406248965
                },
                {
                  "indicator": "fb9c9cbf6925de8c7b6ce8e7a8d5290e628be0b82a58f3e968426c0f734f38f6",
                  "description": "",
                  "created": "2018-03-14T17:25:03",
                  "title": "",
                  "content": "",
                  "type": "FileHash-SHA256",
                  "id": 438581959
                }
              ],
              "more_indicators": false,
              "revision": 1,
              "adversary": "Tropic Trooper",
              "id": "5aa95ae02781860367e354e4",
              "name": "Tropic Troopers New Strategy"
            }
          ]
        },
        "output": [
          "\"CVE-2018-0802\",\"CVE\"",
          "\"fb9c9cbf6925de8c7b6ce8e7a8d5290e628be0b82a58f3e968426c0f734f38f6\",\"FileHash-SHA256\""
        ]
      }
    ],
    "identifier": 49300056
  },
  {
    "context": [
      "\"jq '.credsStore = \\\"ecr-login\\\"' ~/.docker/config.json > ~/.docker/output.json \"",
      "`bash: .docker/output.json: No such file or directory`",
      "jq '.credsStore = \"ecr-login\"' \\",
      "<~/.docker/config.json \\",
      ">~/.docker/output.json"
    ],
    "utterance": "Set the credsStore field to \"ecr-login\" in the config file and write the result to output.json in the .docker directory.",
    "expressions": [
      "jq '.credsStore = \"ecr-login\"' < ~/.docker/config.json > ~/.docker/output.json"
    ],
    "data": [
      {
        "input": {
          "credsStore": "some-old-value",
          "other_field": 123
        },
        "output": {
          "credsStore": "ecr-login",
          "other_field": 123
        }
      }
    ],
    "identifier": 49377438
  },
  {
    "context": [
      "I have a json file on my remote server",
      "I want to add new element to the test.josn from my local machine.",
      "I am trying following command but it is not working.",
      "ssh <test-server> \"jq '.key3 = \"Value3\"' .docker/test.json > .docker/test2.json && mv .docker/test2.json .docker/test.json\"",
      "You can try the following:",
      "ssh <test-server> 'jq \".key3 = \\\"Value3\\\"\" .docker/test.json > .docker/test2.json && mv .docker/test2.json .docker/test.json'"
    ],
    "utterance": "Add a new element with key3 set to Value3 to an object stored in a file on a remote server.",
    "expressions": [
      ".key3 = \"Value3\""
    ],
    "data": [
      {
        "input": {
          "key1": "Value1",
          "Key2": "Value2"
        },
        "output": {
          "key1": "Value1",
          "Key2": "Value2",
          "key3": "Value3"
        }
      }
    ],
    "identifier": 49377973
  },
  {
    "context": [
      "result=$(cat input.json | jq -r '.menu | keys[]')",
      "cat \"$file\" | jq -r '.menu | keys[]' | \nwhile IFS= read -r value; do\n    echo \"$value\"\ndone",
      "result=( $(cat \"$file\" | jq -r '.menu | keys[]') )",
      "jq -r '.menu | keys_unsorted[] | \"--\"+ . +\"--\"' input.json"
    ],
    "utterance": "Print each key of the menu object in the input, each line formatted as --key--.",
    "expressions": [
      ".menu | keys[]",
      ".menu | keys_unsorted[] | \"--\" + . + \"--\""
    ],
    "data": [
      {
        "input": {
          "menu": {
            "id": "file",
            "value": "File",
            "user": {
              "address": "USA",
              "email": "user@gmail.com"
            }
          }
        },
        "output": [
          "--id--",
          "--value--",
          "--user--"
        ]
      }
    ],
    "identifier": 49382979
  },
  {
    "context": [
      "I am trying to get the value of updated_at if actee_type = app.",
      "Based on the sample JSON (minus the erroneous trailing comma) and the stated query, the appropriate jq filter would simply be:\n\n    select (.entity.actee_type==\"app\")\n    | .metadata.updated_at",
      "Based on the comment, the relevant query against the complete JSON would be as above but preceded by `.resources[] | `"
    ],
    "utterance": "Return the value of updated_at where actee_type is app.",
    "expressions": [
      ".resources[] | select (.entity.actee_type==\"app\") | .metadata.updated_at",
      "select (.entity.actee_type==\"app\") | .metadata.updated_at"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "guid": "f9787342b-0d3b-45c5-b7a6-f61c2a12de00",
            "url": "/v2/events/f67a342b-0d3b-45c5-b7a6-f61c2a12de00",
            "created_at": "2018-03-07T17:15:22Z",
            "updated_at": "2018-03-07T17:15:22Z"
          },
          "entity": {
            "type": "audit.app.update",
            "actor": "ae84a203-921d-41a0-97bf-26679342ef47",
            "actor_type": "user",
            "actor_name": "abc@xyz.org",
            "actor_username": "abc.xyz.org",
            "actee": "b9dba536-2aae-455d-aadc-8782bd5ee8d5",
            "actee_type": "app",
            "actee_name": "knpFileUpload",
            "timestamp": "2018-03-07T17:15:22Z",
            "metadata": {
              "request": {
                "state": "STARTED"
              }
            },
            "space_guid": "bcz38b4b-9989-42d2-b6bd-702645e344cf",
            "organization_guid": "axr09940a-a680-4f54-af30-3abfdb76ea2f"
          }
        },
        "output": "2018-03-07T17:15:22Z"
      }
    ],
    "identifier": 49369751
  },
  {
    "context": [
      "I would like to have the line starting with \"cmd\" as the key, and the time value in the next line as \"value\".",
      "It might make more sense to produce JSON objects with more structure, e.g. of the form {\"cmd\": _, \"value\": _}.  Assuming the \"cmd\" line always begins as in statistics.txt, this can also easily be achieved, e.g. by:",
      "jq -Rn '{ cmd: inputs[4:], value: input }' statistics.txt"
    ],
    "utterance": "For each command line followed by its time, extract objects with the command (omitting \"cmd \") as the 'cmd' key and the following time as the 'value' key.",
    "expressions": [
      "jq -Rn '{ cmd: inputs[4:], value: input }' statistics.txt"
    ],
    "data": [
      {
        "input": "cmd ls -lah\n0m1.964s\ncmd echo something\n0m4.183s\ncmd setup-environment\n0m0.401s\n",
        "output": [
          {
            "cmd": "ls -lah",
            "value": "0m1.964s"
          },
          {
            "cmd": "echo something",
            "value": "0m4.183s"
          },
          {
            "cmd": "setup-environment",
            "value": "0m0.401s"
          }
        ]
      }
    ],
    "identifier": 49402278
  },
  {
    "context": [
      "However `jq '.data'` works fine, and the selected data becomes:",
      "However `jq '.data.search'` works fine.",
      "jq '.data.search.edges[] | {node}' works fine, but jq '.data.search.edges[] | {node.name}' gives:\r\njq: error: syntax error, unexpected FIELD, expecting '}' (Unix shell quoting issues?) at <top-level>, line 1:\r\n.data.search.edges[] | {node.name}                             \r\njq: 1 compile error",
      "* `{foo}` for `{\"foo\": .foo}`"
    ],
    "utterance": "Extract the 'name' field from every 'node' object inside the 'edges' array located at 'data.search'",
    "expressions": [
      ".data.search.edges[] | {name: .node.name}"
    ],
    "data": [
      {
        "input": {
          "data": {
            "search": {
              "repositoryCount": 24,
              "edges": [
                {
                  "node": {
                    "name": "leumi-leumicard-bank-data-scraper",
                    "url": "https://github.com/Urigo/leumi-leumicard-bank-data-scraper",
                    "description": "Open bank data for Leumi bank and Leumi card credit card"
                  }
                },
                {
                  "node": {
                    "name": "puppeteer-demo",
                    "url": "https://github.com/xJkit/puppeteer-demo",
                    "description": "A demo for website scrapping by my puppet :>"
                  }
                }
              ]
            }
          }
        },
        "output": [
          {
            "name": "leumi-leumicard-bank-data-scraper"
          },
          {
            "name": "puppeteer-demo"
          }
        ]
      }
    ],
    "identifier": 49398366
  },
  {
    "context": [
      "I need to check if there is at least one creator in a record or not. If there is I give a 1 else a 0 for that field in a CSV-file.",
      "The problem is that the field 'Production' is only an array when there are multiple creators.",
      "The result I want to get in this case is:\n\n    1,\n    0,\n    1,",
      "jq -r '[].recordList.record[].Production | \"\\(if ((type == \"array\" and .[0].creator.name !=\"\") or (type == \"object\" and .creator.name and .creator.name !=\"\")) then 1 else 0 end),\"' file.json",
      "jq -r '[].recordList.record[].Production | ((type == \"array\" and .[0].creator.name) or .creator.name) | if . then \"1,\" else \"0,\" end' file.json"
    ],
    "utterance": "For each record, output 1 if there is a creator present, otherwise 0, handling the case where Production can be an object or an array.",
    "expressions": [
      ".[].recordList.record[].Production | \"\\(if ((type == \"array\" and .[0].creator.name !=\"\") or (type == \"object\" and .creator.name and .creator.name !=\"\")) then 1 else 0 end),\"",
      ".[].recordList.record[].Production | ((type == \"array\" and .[0].creator.name) or .creator.name) | if . then \"1,\" else \"0,\" end"
    ],
    "data": [
      {
        "input": [
          {
            "recordList": {
              "record": [
                {
                  "Production": {
                    "creator": {
                      "name": "A"
                    }
                  }
                },
                {
                  "Production": {}
                },
                {
                  "Production": [
                    {
                      "creator": {
                        "name": "B"
                      }
                    },
                    {
                      "creator": {
                        "name": "C"
                      }
                    }
                  ]
                }
              ]
            }
          }
        ],
        "output": [
          "1,",
          "0,",
          "1,"
        ]
      }
    ],
    "identifier": 49408717
  },
  {
    "context": [
      "if only one service exists, no issues, but if more than one then getting error `string (\"\") and array ([\"ssm.amazonaws.com) cannot be added`",
      "How to get all values for Principal.Service in one row.",
      "It appears that .Principal.Service is either a string or an array of strings, so you need to handle both cases. Consider therefore:\r\n\r\n    def to_s: if type == \"string\" then . else join(\"--\") end;",
      "(.Principal.Service | if type == \"array\" then join(\"--\") else . end)"
    ],
    "utterance": "Display Principal.Service values as a single row, joining multiple services with --, handling both string and array cases.",
    "expressions": [
      ".RoleDetailList | map(select((.AssumeRolePolicyDocument.Statement | length > 0) and (.AssumeRolePolicyDocument.Statement[].Principal.Service) or (.AssumeRolePolicyDocument.Statement[].Principal.AWS) or (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or (.AttachedManagedPolicies | length >0) or (.RolePolicyList | length > 0)) )[] | [.RoleName, ([.RolePolicyList[].PolicyName, ([.AttachedManagedPolicies[].PolicyName] | join(\"--\"))] | join(\" \")), (.AssumeRolePolicyDocument.Statement[] | .Principal.Federated + \"\" + (.Principal.Service | if type == \"array\" then join(\"--\") else . end) + \"\" + .Principal.AWS)] | @csv"
    ],
    "identifier": 49379953
  },
  {
    "context": [
      "I need to check if there is at least one 'term' (that is not empty) for 'creator.role' in a record or not. If there is I give a 1 else a 0 for that field in a CSV-file.",
      "But now I also have the same problem for the field 'creator.role' with the special character '.' and don't know how to handle that.",
      "The output I want to get in this case is:\n\n    1,\n    0,\n    0,\n    1,",
      "jq -r '[].recordList.record[].Production | \"\\(if ((type == \"array\" and any(.[\"creator.role\"].term !=\"\")) \n     or (type == \"object\" and .[\"creator.role\"].term and .[\"creator.role\"].term !=\"\"))\n     then 1 else 0 end),\"' file.json"
    ],
    "utterance": "For each Production entry, output 1 if at least one creator.role term is not empty in object or array form; output 0 otherwise, using the correct handling for keys with dots.",
    "expressions": [
      ".[].recordList.record[].Production | \"\\(if ((type == \\\"array\\\" and any(.[\\\"creator.role\\\"].term !=\\\"\\\")) or (type == \\\"object\\\" and .[\\\"creator.role\\\"].term and .[\\\"creator.role\\\"].term !=\\\"\\\")) then 1 else 0 end),\""
    ],
    "data": [
      {
        "input": [
          {
            "recordList": {
              "record": [
                {
                  "Production": {
                    "creator.role": {
                      "term": "A"
                    }
                  }
                },
                {
                  "Production": {}
                },
                {
                  "Production": {
                    "creator.role": {
                      "term": ""
                    }
                  }
                },
                {
                  "Production": [
                    {
                      "creator.role": {
                        "term": "B"
                      }
                    },
                    {
                      "creator.role": {
                        "term": ""
                      }
                    }
                  ]
                }
              ]
            }
          }
        ],
        "output": [
          "1,",
          "0,",
          "0,",
          "1,"
        ]
      }
    ],
    "identifier": 49427529
  },
  {
    "context": [
      "Is there a filter I am missing to get it to parse the values as well as the higher level structure?",
      "The filter you'll need is `fromjson`, but it should only be applied to the stringified JSON; consider therefore using `|=` as illustrated using your fragment:",
      "jq '.achievements.Vales |= fromjson'",
      "If you want to apply `fromjson` recursively wherever possible, then `recursively` is your friend:",
      "def recursively(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key]  | recursively(f) )} )\n  elif type == \"array\" then map( recursively(f) )\n  else try (f as $f | if $f == . then . else ($f | recursively(f)) end) catch $in\n  end;",
      "recursively(fromjson)"
    ],
    "utterance": "Decode all string values that are themselves valid and parseable as objects or arrays, at any level of nesting, into their corresponding native structures.",
    "expressions": [
      ".achievements.Vales |= fromjson",
      "def recursively(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys[] as $key\n        ( {}; . + { ($key):  ($in[$key]  | recursively(f) )} )\n  elif type == \"array\" then map( recursively(f) )\n  else try (f as $f | if $f == . then . else ($f | recursively(f)) end) catch $in\n  end;\nrecursively(fromjson)"
    ],
    "data": [
      {
        "input": {
          "achievements": {
            "Vales": "[{\"id\":0,\"gamePack\":\"GAME.PACK.0.KK\",\"marblesAmount\":50}]"
          }
        },
        "output": {
          "achievements": {
            "Vales": [
              {
                "id": 0,
                "gamePack": "GAME.PACK.0.KK",
                "marblesAmount": 50
              }
            ]
          }
        }
      }
    ],
    "identifier": 49438164
  },
  {
    "context": [
      "\".data.search.edges[].node | {name, topics: ..|.topics?}\" works, but I want all topics from the same node to be in one array, instead of having same `name` in all different returned results.",
      "by _\"collect into a single array\"_ I meant to get something like this:\n\n    [\n      {\n        \"name\": \"leumi-leumicard-bank-data-scraper\",\n        \"topics\": [\"banking\", \"leumi\", \"api\", \"puppeteer\", \"scraper\", \"open-api\"]\n      }\n    ]",
      "If you wanted to have an array of topics within the nodes instead, just collect them in an array by putting the filter that selects the topics within `[]`.",
      "[.data.search.edges[].node | {name,topic:[.repositoryTopics.nodes[].topic.topics]}]",
      "One way to collect the non-falsey values:\n\n    .data.search.edges[].node \n    | {name, topics: [.. | .topics? | select(.)]}",
      "The result would be:\n\n    {\n      \"name\": \"leumi-leumicard-bank-data-scraper\",\n      \"topics\": [\n        \"banking\",\n        \"leumi\",\n        \"api\",\n        \"puppeteer\",\n        \"scraper\",\n        \"open-api\"\n      ]\n    }"
    ],
    "utterance": "For each node, collect all of its topics properties recursively into a single array so that each node has one name and its list of all topics.",
    "expressions": [
      "[.data.search.edges[].node | {name, topics: [.repositoryTopics.nodes[].topic.topics]}]",
      ".data.search.edges[].node | {name, topics: [.. | .topics? | select(.)]}"
    ],
    "data": [
      {
        "input": {
          "data": {
            "search": {
              "edges": [
                {
                  "node": {
                    "name": "leumi-leumicard-bank-data-scraper",
                    "repositoryTopics": {
                      "nodes": [
                        {
                          "topic": {
                            "topics": "banking"
                          }
                        },
                        {
                          "topic": {
                            "topics": "leumi"
                          }
                        },
                        {
                          "topic": {
                            "topics": "api"
                          }
                        },
                        {
                          "topic": {
                            "topics": "puppeteer"
                          }
                        },
                        {
                          "topic": {
                            "topics": "scraper"
                          }
                        },
                        {
                          "topic": {
                            "topics": "open-api"
                          }
                        }
                      ]
                    }
                  }
                },
                {
                  "node": {
                    "name": "echarts-scrappeteer",
                    "repositoryTopics": {
                      "nodes": []
                    }
                  }
                }
              ]
            }
          }
        },
        "output": [
          {
            "name": "leumi-leumicard-bank-data-scraper",
            "topics": [
              "banking",
              "leumi",
              "api",
              "puppeteer",
              "scraper",
              "open-api"
            ]
          },
          {
            "name": "echarts-scrappeteer",
            "topics": []
          }
        ]
      }
    ],
    "identifier": 49410611
  },
  {
    "context": [
      "I am trying to parse below hash with jq ... and get output like\n    a,string,mykeypair\n    a,int,123",
      "jq -r '.name as $n | .data[] | [$n, .type, .value] | @csv' file.json",
      "jq -r '.name as $n | .data[] | [$n, .type, \"\\(.value)\"] | join(\",\")' file.json",
      "The output:\n    a,string,mykeypair\n    a,int,123"
    ],
    "utterance": "For each object in the data array, output the name, type, and value fields on a single comma-separated line without quotes.",
    "expressions": [
      ".name as $n | .data[] | [$n, .type, \"\\(.value)\"] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "name": "a",
          "data": [
            {
              "sensitive": false,
              "type": "string",
              "value": "mykeypair"
            },
            {
              "sensitive": false,
              "type": "int",
              "value": 123
            }
          ]
        },
        "output": [
          "a,string,mykeypair",
          "a,int,123"
        ]
      }
    ],
    "identifier": 49446308
  },
  {
    "context": [
      "What I would like to do is use a pattern like the following so it also sets the paths at \"acme-b\", \"acme-c\", and so on:",
      "One could also use 'startswith'. It might be appropriate to use 'walk'.",
      "To use 'setpath', one could use 'reduce' (e.g. with 'paths'), e.g.:",
      "    reduce paths as $p (.;\n      if $p[-1] | test(\"^acme-\") then setpath($p; \"mytagname\") else . end)"
    ],
    "utterance": "Set all dependency values whose key starts with 'acme-' to 'mytagname'.",
    "expressions": [
      ".dependencies |= with_entries(if .key|test(\"^acme-\") then .value = \"mytagname\" else . end)",
      "reduce paths as $p (.; if $p[-1] | test(\"^acme-\") then setpath($p; \"mytagname\") else . end)"
    ],
    "identifier": 49514084
  },
  {
    "context": [
      "I have modified the extension file to look like:\r\n\r\n    # json\r\n    regex/\\.json$\r\n        View=%view{ascii} jq '. ' < %f\r\n\r\nAnd now it works as expected, piping result of `jq` to the internal `mc` viewer.",
      "You don't have to use redirection **<** here, you could use just a plain filename **%f**:\r\n\r\n# json\r\nregex/\\.json$\r\n    View=%view{ascii} jq '.' %f\r\n",
      "and as you [mentioned][1] you have to use a simple filter: **.**"
    ],
    "utterance": "Display the contents of a file using a simple filter to pretty-print all data.",
    "expressions": [
      "jq '.' < %f",
      "jq '.' %f"
    ],
    "identifier": 49531563
  },
  {
    "context": [
      "newkey1 should be populated if any of the `.data.assets[].tags[].values` is system or process etc...similarly newkey2 only if market, finance etc.",
      ".data.assets |= map( .newkey1 = if any(.tags[].value; . == \"system\") then \"system\" else null end | .newkey2 = if any(.tags[].value; . == \"market\") then \"market\" else null end )"
    ],
    "utterance": "For each object in data.assets, add newkey1 with value 'system' if any tag has value 'system', and add newkey2 with value 'market' if any tag has value 'market'.",
    "expressions": [
      ".data.assets |= map( .newkey1 = if any(.tags[].value; . == \"system\") then \"system\" else null end | .newkey2 = if any(.tags[].value; . == \"market\") then \"market\" else null end )"
    ],
    "data": [
      {
        "input": {
          "data": {
            "assets": [
              {
                "aDASD": "1056bda9-2598-4fdf-bd99-db3924464a75",
                "KEY": "a7e2ef79-41aa-4a36-9ca1-1f388917eb12.ahnl",
                "key2": "store-order-picking-units-api",
                "key3": "1.0.1",
                "tags": [
                  {
                    "value": "abcd",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "123",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "market",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "mytype"
              }
            ]
          }
        },
        "output": {
          "data": {
            "assets": [
              {
                "aDASD": "1056bda9-2598-4fdf-bd99-db3924464a75",
                "KEY": "a7e2ef79-41aa-4a36-9ca1-1f388917eb12.ahnl",
                "key2": "store-order-picking-units-api",
                "key3": "1.0.1",
                "tags": [
                  {
                    "value": "abcd",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "123",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "market",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "mytype",
                "newkey1": "system",
                "newkey2": "market"
              }
            ]
          }
        }
      }
    ],
    "identifier": 49439519
  },
  {
    "context": [
      "I need in list of schema.table filtered by status==1.",
      "The expected result is:\r\n\r\n    [ \"schema1.table2\", \"schema2.table2\" ]",
      "How to replace table.schema with appropriated keys of parent objects?",
      "jq -r '. as $o | paths \r\n       | select(length == 3) \r\n       | select($o[.[0]][.[1]][.[2]] == 1) \r\n       | .[0] +\".\"+ .[1]' file.json",
      "[to_entries[]\r\n |  .key as $k\r\n | .value | to_entries | map(select(.value.status == 1))[]\r\n | [$k, .key]\r\n | join(\".\") ]",
      "[tostream as [$p,$v]\n  | select($p[-1] == \"status\" and $v == 1)\n  | $p[:2] | join(\".\")\n]",
      "path(.[]|.[]|select(.status==1))|join(\".\")"
    ],
    "utterance": "List all parent.child keys where status equals 1, formatted as schema.table.",
    "expressions": [
      "[to_entries[] | .key as $k | .value | to_entries | map(select(.value.status == 1))[] | [$k, .key] | join(\".\")]",
      "[tostream as [$p,$v] | select($p[-1] == \"status\" and $v == 1) | $p[:2] | join(\".\")]",
      "path(.[]|.[]|select(.status==1))|join(\".\")",
      ". as $o | paths | select(length == 3) | select($o[.[0]][.[1]][.[2]] == 1) | .[0] +\".\"+ .[1]"
    ],
    "data": [
      {
        "input": {
          "schema1": {
            "table1": {
              "status": 0
            },
            "table2": {
              "status": 1
            }
          },
          "schema2": {
            "table1": {
              "status": 0
            },
            "table2": {
              "status": 1
            }
          }
        },
        "output": [
          "schema1.table2",
          "schema2.table2"
        ]
      }
    ],
    "identifier": 49448001
  },
  {
    "context": [
      "I want to use a `jq` expression to generate the following:\r\n\r\n    [\"normal\", \"one\", \"two\"]\r\n\r\nThe condition to select the key is that its corresponding value is an `object` type that has a key `description`. In this case, keys `simple` and `arbitrary` don't qualify.",
      "jq -c '[.. | objects | to_entries[] \r\n              | select(.value | has(\"description\")?) | .key]'",
      "jq --stream '[select(length==2) | .[0] | select(.[-1] == \"description\") | .[-2]]'"
    ],
    "utterance": "Return all keys whose associated value is an object and contains the key description, recursively.",
    "expressions": [
      "[.. | objects | to_entries[] | select(.value | has(\"description\")?) | .key]",
      "[select(length==2) | .[0] | select(.[-1] == \"description\") | .[-2]]"
    ],
    "data": [
      {
        "input": {
          "simple": 42,
          "normal": {
            "description": "NORMAL"
          },
          "combo": {
            "one": {
              "description": "ONE"
            },
            "two": {
              "description": "TWO"
            },
            "arbitrary": {
              "foo": 42
            }
          }
        },
        "output": [
          "normal",
          "one",
          "two"
        ]
      }
    ],
    "identifier": 49541634
  },
  {
    "context": [
      "In a JSON object, given the string `\"0.0000086900\"` as the value of a key-value pair, if I do `|tonumber` on this, `8.69e-06` gets returned.",
      "How can I ensure that only decimals are ever returned?",
      "Here is a simple illustration of what can be done.",
      "def to_decimal:\n  def rpad(n): if (n > length) then . + ((n - length) * \"0\") else . end;\n  def lpad(n): if (n > length) then ((n - length) * \"0\") + . else . end;\n\n  tostring\n  | . as $s\n  | capture( \"(?<sgn>[+-]?)(?<left>[0-9]*)(?<p>\\.?)(?<right>[0-9]*)(?<e>[Ee]?)(?<exp>[+-]?[0-9]+)\" )\n  | if .e == \"\" then (if .sgn == \"+\" then $s[1:] else $s end)\n    else (.left|length) as $len\n    | (.exp|tonumber) as $exp\n    | (if .sgn == \"-\" then \"-\" else \"\" end ) as $sgn\n    | if $exp < 0 then \".\" + (.left | lpad(1 - $exp - $len)) + .right\n      else (.left | rpad($exp - $len)) + \".\" + .right\n      end\n      | $sgn + .\n    end ;"
    ],
    "utterance": "Convert a numeric string such as \"0.0000086900\" to its decimal representation as a string, avoiding scientific notation.",
    "expressions": [
      "def to_decimal:\n  def rpad(n): if (n > length) then . + ((n - length) * \"0\") else . end;\n  def lpad(n): if (n > length) then ((n - length) * \"0\") + . else . end;\n\n  tostring\n  | . as $s\n  | capture( \"(?<sgn>[+-]?)(?<left>[0-9]*)(?<p>\\.?)(?<right>[0-9]*)(?<e>[Ee]?)(?<exp>[+-]?[0-9]+)\" )\n  | if .e == \"\" then (if .sgn == \"+\" then $s[1:] else $s end)\n    else (.left|length) as $len\n    | (.exp|tonumber) as $exp\n    | (if .sgn == \"-\" then \"-\" else \"\" end ) as $sgn\n    | if $exp < 0 then \".\" + (.left | lpad(1 - $exp - $len)) + .right\n      else (.left | rpad($exp - $len)) + \".\" + .right\n      end\n      | $sgn + .\n    end ;"
    ],
    "data": [
      {
        "input": "\"0.0000086900\"",
        "output": "0.0000086900"
      },
      {
        "input": "8.69e-06",
        "output": "0.00000869"
      }
    ],
    "identifier": 49502120
  },
  {
    "context": [
      "how can i get countries-sapi  or inventory-list-api I mean whatever is there before the version. the version can be as simple as `1.0` or `1.0.1-snapshot` etc..",
      "sub(\" *- *[0-9]+\\\\.[0-9]+.*$\"; \"\")",
      "jq '.[] | match(\"^.*(?=-\\\\d+\\\\.)\") | .string'",
      "jq '.[] | split(\"-1.\") | first'"
    ],
    "utterance": "Extract the part of each string before the version segment, matching both simple and complex version patterns.",
    "expressions": [
      ".[] | sub(\" *- *[0-9]+\\\\.[0-9]+.*$\"; \"\")",
      ".[] | match(\"^.*(?=-\\\\d+\\\\.)\") | .string",
      ".[] | split(\"-1.\") | first"
    ],
    "data": [
      {
        "input": [
          "countries-sapi-1.0",
          "inventory-list-api-1.0-snapshot"
        ],
        "output": [
          "countries-sapi",
          "inventory-list-api"
        ]
      }
    ],
    "identifier": 49551805
  },
  {
    "context": [
      "I need the complete string from beginning till the starting number. I don't want anything which is there after the number. And then the add new field with key as newkey and value should be extracted string without the number. Thus, the output should contain old fields as well as new one.",
      "jq 'map(. + (.name | capture(\"(?<newkey>.+)-[0-9]+\")) )' input.json",
      "The output:\n[\n  {\n    \"id\": \"abc\",\n    \"name\": \"name-middlenane-lastname-1\",\n    \"newkey\": \"name-middlenane-lastname\"\n  },\n  {\n    \"id\": \"123\",\n    \"name\": \"fname-flast-2\",\n    \"newkey\": \"fname-flast\"\n  }\n]"
    ],
    "utterance": "For an array of objects, extract the part of the string field 'name' that occurs before the trailing hyphen-number, and add it as a new field 'newkey' while preserving existing fields.",
    "expressions": [
      "map(. + (.name | capture(\"(?<newkey>.+)-[0-9]+\")) )"
    ],
    "data": [
      {
        "input": [
          {
            "id": "abc",
            "name": "name-middlenane-lastname-1"
          },
          {
            "id": "123",
            "name": "fname-flast-2"
          }
        ],
        "output": [
          {
            "id": "abc",
            "name": "name-middlenane-lastname-1",
            "newkey": "name-middlenane-lastname"
          },
          {
            "id": "123",
            "name": "fname-flast-2",
            "newkey": "fname-flast"
          }
        ]
      }
    ],
    "identifier": 49553691
  },
  {
    "context": [
      "You want only items with `downloads==0`",
      "You want only items whose name contains \"SNAPSHOT\"",
      "The following will accomplish that:\n\n    jq -r '[.values[] | {(.name): .downloads}]\n    | add\n    | to_entries[]\n    | select(.value == 0)\n    | .key | select(contains(\"SNAPSHOT\"))'",
      "The use of `.[]` in this manner results in the Cartesian product being formed -- that is, the above expression will emit n*n JSON sets, where n is the length of `.values`.  You evidently intended to write:\n\n    .values[] | {name: .name, downloads: .downloads} \n\nwhich can be abbreviated to:\n\n    .values[] | {name, downloads} \n"
    ],
    "utterance": "List the names of all artifacts with zero downloads whose name contains 'SNAPSHOT'.",
    "expressions": [
      ".values[] | select(.downloads == 0) | select(.name | contains(\"SNAPSHOT\")) | .name",
      "[.values[] | {(.name): .downloads}] | add | to_entries[] | select(.value == 0) | .key | select(contains(\"SNAPSHOT\"))",
      "reduce (.values[] | select(.name | contains(\"SNAPSHOT\"))) as $v ({}; .[$v.name] += $v.downloads) | with_entries(select(.value == 0)) | keys_unsorted[]"
    ],
    "data": [
      {
        "input": {
          "pagelen": 10,
          "size": 40,
          "values": [
            {
              "name": "myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip",
              "links": {
                "self": {
                  "href": "https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip"
                }
              },
              "downloads": 2,
              "created_on": "2018-03-15T17:50:00.157310+00:00",
              "user": {
                "username": "me",
                "display_name": "me",
                "type": "user",
                "uuid": "{3051ec5f-cc92-4bc3-b291-38189a490a89}",
                "links": {
                  "self": {
                    "href": "https://api.bitbucket.org/2.0/users/me"
                  },
                  "html": {
                    "href": "https://bitbucket.org/me/"
                  },
                  "avatar": {
                    "href": "https://bitbucket.org/account/me/avatar/32/"
                  }
                }
              },
              "type": "download",
              "size": 430894
            },
            {
              "name": "myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip",
              "links": {
                "self": {
                  "href": "https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip"
                }
              },
              "downloads": 0,
              "created_on": "2018-03-15T17:50:00.157310+00:00",
              "user": {
                "username": "me",
                "display_name": "me",
                "type": "user",
                "uuid": "{3051ec5f-cc92-4bc3-b291-38189a490a89}",
                "links": {
                  "self": {
                    "href": "https://api.bitbucket.org/2.0/users/me"
                  },
                  "html": {
                    "href": "https://bitbucket.org/me/"
                  },
                  "avatar": {
                    "href": "https://bitbucket.org/account/me/avatar/32/"
                  }
                }
              },
              "type": "download",
              "size": 430894
            },
            {
              "name": "myproject_1.0_mc_3.5.1.zip",
              "links": {
                "self": {
                  "href": "https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.1.zip"
                }
              },
              "downloads": 5,
              "created_on": "2018-03-15T17:49:14.885544+00:00",
              "user": {
                "username": "me",
                "display_name": "me",
                "type": "user",
                "uuid": "{3051ec5f-cc92-4bc3-b291-38189a490a89}",
                "links": {
                  "self": {
                    "href": "https://api.bitbucket.org/2.0/users/me"
                  },
                  "html": {
                    "href": "https://bitbucket.org/me/"
                  },
                  "avatar": {
                    "href": "https://bitbucket.org/account/me/avatar/32/"
                  }
                }
              },
              "type": "download",
              "size": 430934
            }
          ],
          "page": 1,
          "next": "https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads?pagelen=10&page=2"
        },
        "output": "myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip"
      }
    ],
    "identifier": 49323261
  },
  {
    "context": [
      "And I'm trying to get only the following data:",
      "201110131738QP27N",
      "201803271459ICV69",
      "2018032715008ZM2G",
      "201803281536PSKR4",
      "Use the [`keys` builtin function](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions#keys,keys_unsorted) of `jq`.",
      "$ cat input.json | jq 'keys'",
      "To get the raw output without an array use `|.[]` to unwrap it",
      "jq --raw-output 'keys | .[]'  input.json",
      "or more simply written as just `jq --raw-output 'keys[]'`"
    ],
    "utterance": "List the top-level keys as plain text, one per line.",
    "expressions": [
      "keys",
      "keys[]",
      "keys | .[]"
    ],
    "data": [
      {
        "input": {
          "201110131738QP27N": {
            "parent": 17,
            "name": "CentralServer",
            "status": "Active",
            "count": 6
          },
          "201803271459ICV69": {
            "name": "subaccount1",
            "status": "Active",
            "count": 1
          },
          "2018032715008ZM2G": {
            "name": "subaccount2",
            "status": "Active",
            "count": 1
          },
          "201803281536PSKR4": {
            "name": "Este e um teste",
            "status": "Active"
          }
        },
        "output": [
          "201110131738QP27N",
          "201803271459ICV69",
          "2018032715008ZM2G",
          "201803281536PSKR4"
        ]
      }
    ],
    "identifier": 49556242
  },
  {
    "context": [
      "I want to match `toPayBtn_10021` but the number after `toPayBtn_` is dynamic, it can be `toPayBtn_10` `toPayBtn_2` `toPayBtn_847` etc...",
      ".[] | select( test(\"^toPayBtn_\") )"
    ],
    "utterance": "Select all array elements whose value starts with 'toPayBtn_'.",
    "expressions": [
      ".[] | select(test(\"^toPayBtn_\"))"
    ],
    "data": [
      {
        "input": [
          "delivery_1b36940ef75c49a8864d8cb3ea6a3a9f",
          "toPayBtn_10021",
          "item_fdd0772d0dd74dea93033761ca14e781",
          "item_4f1a3f6fd3afdb940be008a0d325f9ad",
          "delivery_d69dc5e9df971c9b2b1736c2231cb4a9",
          "orderTotal_1",
          "address_BILLING#1",
          "delivery_185e36d98d5e4cc1808e59e44df8c71c",
          "voucherInput_1",
          "address_DELIVERY#1",
          "item_864e1a7daf2aa424cbcb2251d55abda9",
          "item_913196f953cbe8cfc2851c8fa9498607"
        ],
        "output": [
          "toPayBtn_10021"
        ]
      }
    ],
    "identifier": 49566793
  },
  {
    "context": [
      "In a large json file, I want to remove some elements from a nested list, but keep the overall structure of the document.",
      "The required output just has one element of the 'filter_this' block removed:",
      "{\n  \"keep_untouched\": {\n    \"keep_this\": [\n      \"this\",\n      \"list\"\n    ]\n  },\n  \"filter_this\": [\n    {\"keep\" : \"true\"},\n    {\n      \"keep\": \"true\",\n      \"extra\": \"keeper\"\n    } ,\n  ]\n}",
      "Extract all but .filter_this\n< $INPUT jq -c --stream 'select(length==2 and .[0][0] != \"filter_this\")' |\n    jq -nc 'reduce inputs as [$p,$x] (null; setpath($p;$x))' > $TMP.parent",
      "# Need jq > 1.5\n# Extract the 'keepers'\n< $INPUT jq -n -c --stream '\n  [fromstream(2|truncate_stream(inputs))\n   | select(type == \"object\" and .keep == \"true\")]\n  ' $INPUT > $TMP.keepers",
      "# Insert the filtered list into the parent object:\njq -s '. as $in | .[0] | (.filter_this |= $in[1])' $TMP.parent $TMP.keepers > result.json"
    ],
    "utterance": "Remove all elements from the 'filter_this' array whose 'keep' field is not 'true', preserving the rest of the document unchanged.",
    "expressions": [
      "jq -c --stream 'select(length==2 and .[0][0] != \"filter_this\")' input.json | jq -nc 'reduce inputs as [$p,$x] (null; setpath($p;$x))' > parent.json",
      "jq -n -c --stream '[fromstream(2|truncate_stream(inputs)) | select(type == \"object\" and .keep == \"true\")]' input.json > keepers.json",
      "jq -s '. as $in | .[0] | (.filter_this |= $in[1])' parent.json keepers.json"
    ],
    "data": [
      {
        "input": {
          "keep_untouched": {
            "keep_this": [
              "this",
              "list"
            ]
          },
          "filter_this": [
            {
              "keep": "true"
            },
            {
              "keep": "true",
              "extra": "keeper"
            },
            {
              "keep": "false",
              "extra": "non-keeper"
            }
          ]
        },
        "output": {
          "keep_untouched": {
            "keep_this": [
              "this",
              "list"
            ]
          },
          "filter_this": [
            {
              "keep": "true"
            },
            {
              "keep": "true",
              "extra": "keeper"
            }
          ]
        }
      }
    ],
    "identifier": 49531722
  },
  {
    "context": [
      "I inform \"**subaccount1**\" on the command and jq returns me: **201803271459ICV69**",
      "jq -r 'to_entries[] | select(.value.name == \"subaccount1\").key' file.json"
    ],
    "utterance": "Return the object key where the field 'name' equals 'subaccount1'.",
    "expressions": [
      "to_entries[] | select(.value.name == \"subaccount1\").key"
    ],
    "data": [
      {
        "input": {
          "201110131738QP27N": {
            "parent": 17,
            "name": "CentralServer",
            "status": "Active",
            "count": 6
          },
          "201803271459ICV69": {
            "name": "subaccount1",
            "status": "Active",
            "count": 1
          },
          "2018032715008ZM2G": {
            "name": "subaccount2",
            "status": "Active",
            "count": 1
          },
          "201803281536PSKR4": {
            "name": "Este e um teste",
            "status": "Active"
          }
        },
        "output": "201803271459ICV69"
      }
    ],
    "identifier": 49574764
  },
  {
    "context": [
      "The input is an array object. I need to add new key which is the value of key **server**. The value of this new key should value of the key **status**.",
      "jq '.[] |= . + {(.server):.status}' file.json",
      ". + {(.server): .status}",
      "map(. + {(.server): .status})",
      "map( .[.server] = .status )"
    ],
    "utterance": "For each object in an array, add a new key whose name is the value of the server key and whose value is the value of the status key.",
    "expressions": [
      "map(. + {(.server): .status})",
      "map( .[.server] = .status )",
      ".[] |= . + {(.server):.status}"
    ],
    "data": [
      {
        "input": [
          {
            "organizationId": "org1",
            "runtimeVersion": "3545",
            "type": "rest-api",
            "server": "test1",
            "status": "UP"
          }
        ],
        "output": [
          {
            "organizationId": "org1",
            "runtimeVersion": "3545",
            "type": "rest-api",
            "server": "test1",
            "status": "UP",
            "test1": "UP"
          }
        ]
      }
    ],
    "identifier": 49577421
  },
  {
    "context": [
      "I want the output to be a single JSON object where the key is the `.entity.name` and the value is the `.metadata.guid`.",
      "jq -r '.entity.name as $name|.metadata.guid as $guid | { ($name) : ($guid) }' input.json | jq -s add",
      "With single **`jq`** command:\n\n    jq -s '[.[] | { (.entity.name): .metadata.guid }] | add' input.json",
      "The output:\n\n    {\n      \"first\": \"07f90eed-105d-41b2-bc20-4c20dfb51653\",\n      \"second\": \"da187e3a-8db9-49fd-8c05-41f29cf87f51\",\n      \"third\": \"6685c3af-5427-4add-8764-7b18ae3c23bb\"\n    }"
    ],
    "utterance": "Produce an object where each key is the value of entity.name and each value is the corresponding metadata.guid, combining multiple input objects into one object.",
    "expressions": [
      "jq -s '[.[] | { (.entity.name): .metadata.guid }] | add' input.json",
      "jq '{(.entity.name): .metadata.guid}' input.json | jq -s add"
    ],
    "data": [
      {
        "input": [
          {
            "metadata": {
              "guid": "07f90eed-105d-41b2-bc20-4c20dfb51653"
            },
            "entity": {
              "name": "first"
            }
          },
          {
            "metadata": {
              "guid": "da187e3a-8db9-49fd-8c05-41f29cf87f51"
            },
            "entity": {
              "name": "second"
            }
          },
          {
            "metadata": {
              "guid": "6685c3af-5427-4add-8764-7b18ae3c23bb"
            },
            "entity": {
              "name": "third"
            }
          }
        ],
        "output": {
          "first": "07f90eed-105d-41b2-bc20-4c20dfb51653",
          "second": "da187e3a-8db9-49fd-8c05-41f29cf87f51",
          "third": "6685c3af-5427-4add-8764-7b18ae3c23bb"
        }
      }
    ],
    "identifier": 49573125
  },
  {
    "context": [
      "My objective is to merge two objects if they have same value and leave other objects intact.",
      "Now the problem I'm facing is I'm loosing other objects **\"organizationId\": \"org2\"** from **input1.json** and **\"organizationId\": \"org3\"** from **input2.json** which doesn't exist in each others file.",
      "I do need to preserve any other objects from both the files even if there is no match.",
      "solution to get all objects (grouped & ungrouped), use below",
      "`jq -s '[ .[0] + .[1] | group_by(.organizationId)[] |add ]' \u00ecnput1.json input2.json`"
    ],
    "utterance": "Merge arrays from two files by combining objects with the same organizationId and preserving unique objects from both files.",
    "expressions": [
      "[ .[0] + .[1] | group_by(.organizationId)[] | add ]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "organizationId": "org1",
              "test1": "UP",
              "key1": "value1"
            },
            {
              "organizationId": "org2",
              "test1": "UP",
              "key1": "value3"
            }
          ],
          [
            {
              "organizationId": "org1",
              "test2": "DOWN",
              "key1": "value4"
            },
            {
              "organizationId": "org3",
              "test2": "DOWN",
              "key1": "value5"
            }
          ]
        ],
        "output": [
          {
            "organizationId": "org1",
            "test1": "UP",
            "key1": "value4",
            "test2": "DOWN"
          },
          {
            "organizationId": "org2",
            "test1": "UP",
            "key1": "value3"
          },
          {
            "organizationId": "org3",
            "test2": "DOWN",
            "key1": "value5"
          }
        ]
      }
    ],
    "identifier": 49586355
  },
  {
    "context": [
      "I need to get `orderTotal_8` but please note that the number `8` is always changing, so it can be `orderTotal_10` or `orderTotal_3` etc... How can I get this key with pure `jq` command if possible, without the help of grep / awk ? So the result should be like this `orderTotal_8`",
      ".module | .data | keys | map(select(test(\"^orderTotal_\")))",
      ".module | .data | keys[] | select(test(\"^orderTotal_\"))"
    ],
    "utterance": "Get all keys under .module.data whose name starts with 'orderTotal_'",
    "expressions": [
      ".module | .data | keys | map(select(test(\"^orderTotal_\")))",
      ".module | .data | keys[] | select(test(\"^orderTotal_\"))"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "module": {
            "endpoint": {
              "mode": "pc",
              "protocolVersion": "2.0"
            },
            "reload": true,
            "data": {
              "container_C": {},
              "delivery_3": {},
              "delivery_d43597338a": {},
              "delivery_dfdaf8a8a": {},
              "floatTips_4": {},
              "item_i7790e0f9": {},
              "item_i77997d6b": {},
              "item_i7799f86e": {},
              "leftContainer_CL": {},
              "listHeader_H": {},
              "location_2": {},
              "orderSummary_6": {},
              "orderTotal_8": {},
              "package_p43597338a": {},
              "package_pfdaf8a8a": {},
              "rightContainer_CR": {},
              "root_0": {},
              "shop_43597338a_s2c": {},
              "shop_fdaf8a8a_s23f9": {},
              "voucherInput_7": {}
            },
            "hierarchy": {},
            "linkage": {}
          }
        },
        "output": [
          "orderTotal_8"
        ]
      }
    ],
    "identifier": 49542398
  },
  {
    "context": [
      "I want to get `toPayBtn_10021` but the number `10021` is dynamic. So it can be `toPayBtn_34` `toPayBtn_21` etc.",
      "Regex doesn't seem to work with `jq` How do I fix it ?",
      "with_entries( select(.key | test(\"^toPayBtn_\")) )",
      "produces the output you want.  You might want to tweak the regex."
    ],
    "utterance": "Return all objects whose top-level key starts with 'toPayBtn_'.",
    "expressions": [
      "with_entries(select(.key | test(\"^toPayBtn_\")))"
    ],
    "data": [
      {
        "input": {
          "orderTotal_1": {
            "fields": {
              "button": {
                "actionDialog": null,
                "actionUrl": null,
                "clicked": false,
                "enable": true,
                "text": "LANJUTKAN KE PEMBAYARAN",
                "textColor": null
              },
              "payment": {
                "pay": "Rp1.953.800",
                "taxTip": "Termasuk PPN, jika berlaku.",
                "title": "Total"
              },
              "timestamp": 1522355946093
            },
            "id": "1",
            "tag": "orderTotal",
            "type": "biz"
          },
          "rightContainer_10010": {
            "fields": {
              "css": {
                "backgroundColor": null,
                "floatPosition": "right",
                "marginTop": null,
                "width": "388px"
              }
            },
            "id": "10010",
            "tag": "rightContainer",
            "type": "container"
          },
          "toPayBtn_10021": {
            "fields": {
              "clicked": false,
              "enable": true,
              "text": "LANJUTKAN KE PEMBAYARAN"
            },
            "id": "10021",
            "tag": "toPayBtn",
            "type": "biz"
          },
          "voucherInput_1": {
            "fields": {
              "buttonText": "GUNAKAN",
              "placeHolder": "Masukkan Kode Voucher",
              "status": "default"
            },
            "id": "1",
            "tag": "voucherInput",
            "type": "biz"
          }
        },
        "output": {
          "toPayBtn_10021": {
            "fields": {
              "clicked": false,
              "enable": true,
              "text": "LANJUTKAN KE PEMBAYARAN"
            },
            "id": "10021",
            "tag": "toPayBtn",
            "type": "biz"
          }
        }
      }
    ],
    "identifier": 49565829
  },
  {
    "context": [
      "And I want to add {\"operation\":\"delete\"} right below cartItemId and then save the JSON data to a file. The result that I want is like this:\n\n    {\n    \t\"success\": true,\n    \t\"module\": {\n    \t\t\"data\": {\n    \t\t\t\"item_i77f664a2\": {\n    \t\t\t\t\"id\": \"i77f664a2\",\n    \t\t\t\t\"tag\": \"item\",\n    \t\t\t\t\"fields\": {\n    \t\t\t\t\t\"cartItemId\": 2012636322,\n    \t\t\t\t\t\"operation\": \"delete\"\n    \t\t\t\t},\n    \t\t\t\t\"type\": \"biz\"\n    \t\t\t}\n    \t\t}\n    \t}\n    }",
      "jq '.module.data.item_i77f664a2.fields += {\"operation\":\"delete\"}'\n\nproduces the output you indicate you want:"
    ],
    "utterance": "Add an operation: \"delete\" field to the fields object under module.data.item_i77f664a2.",
    "expressions": [
      ".module.data.item_i77f664a2.fields += {\"operation\":\"delete\"}"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "module": {
            "data": {
              "item_i77f664a2": {
                "id": "i77f664a2",
                "tag": "item",
                "fields": {
                  "cartItemId": 2012636322
                },
                "type": "biz"
              }
            }
          }
        },
        "output": {
          "success": true,
          "module": {
            "data": {
              "item_i77f664a2": {
                "id": "i77f664a2",
                "tag": "item",
                "fields": {
                  "cartItemId": 2012636322,
                  "operation": "delete"
                },
                "type": "biz"
              }
            }
          }
        }
      }
    ],
    "identifier": 49632521
  },
  {
    "context": [
      "And I want to insert",
      "\"offline_11018\": [ \"instruction_908\", \"checkboxList_11019\" ]",
      "Between `\"mainContainer_11007\"` and `\"orderWrap_10012\"` so the result I want should look like this:",
      "jq --raw-output '.hierarchy.structure + {\"offline_11018\": [\"instruction_908\",\"checkboxList_11019\"]}'",
      "But that's not what I want, I want to insert it between two other keys. How can I do it with the jq command?",
      "The simplest approach would be to use `to_entries` to convert `.hierarchy.structure` into an array, perform the insertion, and then use `from_entries` to reconstitute the object, along the lines of:",
      "{ \"offline_11018\": [ \"instruction_908\", \"checkboxList_11019\" ] } as $x",
      "| .hierarchy.structure |= (to_entries",
      "| (1 + indexof( .value | index(\"mainContainer_11007\") )) as $ix",
      "| .[:$ix] + ($x | to_entries) + .[$ix:]",
      "| from_entries)"
    ],
    "utterance": "Insert a key 'offline_11018' with value [\"instruction_908\",\"checkboxList_11019\"] immediately after the key 'mainContainer_11007' in the 'structure' object, preserving the order of keys.",
    "expressions": [
      "{ \"offline_11018\": [ \"instruction_908\", \"checkboxList_11019\" ] } as $x\n| .hierarchy.structure |= (to_entries\n    | (1 + indexof( .key == \"mainContainer_11007\" )) as $ix\n    | .[:$ix] + ($x | to_entries) + .[$ix:]\n    | from_entries)"
    ],
    "data": [
      {
        "input": {
          "hierarchy": {
            "structure": {
              "card_11001": [
                "addCard_4111"
              ],
              "container_11006": [
                "mainContainer_11007",
                "subContainer_10016"
              ],
              "mainContainer_11007": [
                "paymentMethodList_10001"
              ],
              "orderWrap_10012": [
                "orderSummary_10005"
              ],
              "paymentMethodList_10001": [
                "card_11001",
                "placeOrder_10013"
              ],
              "root_10000": [
                "payNotice_11011",
                "payNotice_10020",
                "container_11006",
                "placeOrderResultAction_10004"
              ],
              "subContainer_10016": [
                "orderWrap_10012",
                "footer_10014"
              ]
            }
          }
        },
        "output": {
          "hierarchy": {
            "structure": {
              "card_11001": [
                "addCard_4111"
              ],
              "container_11006": [
                "mainContainer_11007",
                "subContainer_10016"
              ],
              "mainContainer_11007": [
                "paymentMethodList_10001"
              ],
              "offline_11018": [
                "instruction_908",
                "checkboxList_11019"
              ],
              "orderWrap_10012": [
                "orderSummary_10005"
              ],
              "paymentMethodList_10001": [
                "card_11001",
                "placeOrder_10013"
              ],
              "root_10000": [
                "payNotice_11011",
                "payNotice_10020",
                "container_11006",
                "placeOrderResultAction_10004"
              ],
              "subContainer_10016": [
                "orderWrap_10012",
                "footer_10014"
              ]
            }
          }
        }
      }
    ],
    "identifier": 49589613
  },
  {
    "context": [
      "All i want is inside my statement array object i want to add new object + modify existing object.",
      "How can i do this two things in single command?",
      "to combine the two operations, simply combine them into a pipeline (i.e., using `|`).",
      ".Statement += [ { \"Sid\": \"AllowForSpecificLambda\", \"Effect\": \"Allow\", \"Principal\": { \"AWS\": [ \"arn:aws:iam::XXXXXXXXXX:role/lambda_allow_pretoken_generation\" ] }, \"Action\": \"s3:Get*\",\"Resource\": [ \"arn:aws:s3:::test-XXXX-cognito-settings-\" + $region ]} ] | .Statement[0].Condition.StringNotLike.\"aws:userId\" += [\"Hello\"]"
    ],
    "utterance": "Add a new object to the Statement array and append \"Hello\" to the aws:userId array inside the Condition.StringNotLike of the first Statement object in a single command.",
    "expressions": [
      ".Statement += [ { \"Sid\": \"AllowForSpecificLambda\", \"Effect\": \"Allow\", \"Principal\": { \"AWS\": [ \"arn:aws:iam::XXXXXXXXXX:role/lambda_allow_pretoken_generation\" ] }, \"Action\": \"s3:Get*\", \"Resource\": [ \"arn:aws:s3:::test-XXXX-cognito-settings-\" + $region ] } ] | .Statement[0].Condition.StringNotLike.\"aws:userId\" += [\"Hello\"]"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Sid": "AllowFullAccess",
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::XXXX:user/test",
                  "arn:aws:iam::XXXX:root"
                ]
              },
              "Action": "s3:*",
              "Resource": [
                "arn:aws:s3:::test-dev-cognito-settings-us-west-2/*"
              ],
              "Condition": {
                "StringNotLike": {
                  "aws:userId": [
                    "AZASDASDSADA"
                  ]
                }
              }
            }
          ]
        },
        "output": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Sid": "AllowFullAccess",
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::XXXX:user/test",
                  "arn:aws:iam::XXXX:root"
                ]
              },
              "Action": "s3:*",
              "Resource": [
                "arn:aws:s3:::test-dev-cognito-settings-us-west-2/*"
              ],
              "Condition": {
                "StringNotLike": {
                  "aws:userId": [
                    "AZASDASDSADA",
                    "Hello"
                  ]
                }
              }
            },
            {
              "Sid": "AllowForSpecificLambda",
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::XXXXXXXXXX:role/lambda_allow_pretoken_generation"
                ]
              },
              "Action": "s3:Get*",
              "Resource": [
                "arn:aws:s3:::test-XXXX-cognito-settings-REGION"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 49629818
  },
  {
    "context": [
      "The problem is that I want this condition to apply for every object inside the array but I'm not able to do that. It is getting applied to the first object only.",
      "The following, by contrast, takes its cue from (that is, produces) the given output:\n\n    .data.assets |=\n      map( if any(.tags[].value; . == \"sourcing\") then . + {\"domain\":\"sourcing\"}\n           elif any(.tags[].value; . == \"supply-chain\") then . + {\"domain\":\"supply-chain\"}\n           else . end )"
    ],
    "utterance": "For each object in data.assets, add a domain property set to \"sourcing\" if any tag's value is \"sourcing\", or to \"supply-chain\" if any tag's value is \"supply-chain\".",
    "expressions": [
      ".data.assets |= map( if any(.tags[].value; . == \"sourcing\") then . + {\"domain\":\"sourcing\"} elif any(.tags[].value; . == \"supply-chain\") then . + {\"domain\":\"supply-chain\"} else . end )"
    ],
    "data": [
      {
        "input": {
          "data": {
            "assets": [
              {
                "organizationId": "1056bda9-2598-4fdf-bd99-db3924464a75",
                "createdAt": "2018-03-14T14:41:41.154Z",
                "tags": [
                  {
                    "value": "raml",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "api",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "v1",
                    "key": "product-api-version",
                    "mutable": false
                  },
                  {
                    "value": "has-mule4-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "has-mule3-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "sourcing",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "rest-api"
              },
              {
                "organizationId": "SASAAs",
                "createdAt": "2018-03-14T14:41:41.154Z",
                "tags": [
                  {
                    "value": "raml",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "api",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "v1",
                    "key": "product-api-version",
                    "mutable": false
                  },
                  {
                    "value": "has-mule4-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "has-mule3-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "supply-chain",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "rest-api"
              }
            ]
          }
        },
        "output": {
          "data": {
            "assets": [
              {
                "organizationId": "1056bda9-2598-4fdf-bd99-db3924464a75",
                "createdAt": "2018-03-14T14:41:41.154Z",
                "tags": [
                  {
                    "value": "raml",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "api",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "v1",
                    "key": "product-api-version",
                    "mutable": false
                  },
                  {
                    "value": "has-mule4-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "has-mule3-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "sourcing",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "rest-api",
                "domain": "sourcing"
              },
              {
                "organizationId": "SASAAs",
                "createdAt": "2018-03-14T14:41:41.154Z",
                "tags": [
                  {
                    "value": "raml",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "rest",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "api",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "v1",
                    "key": "product-api-version",
                    "mutable": false
                  },
                  {
                    "value": "has-mule4-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "has-mule3-connector",
                    "key": null,
                    "mutable": false
                  },
                  {
                    "value": "system",
                    "key": null,
                    "mutable": true
                  },
                  {
                    "value": "supply-chain",
                    "key": null,
                    "mutable": true
                  }
                ],
                "type": "rest-api",
                "domain": "supply-chain"
              }
            ]
          }
        }
      }
    ],
    "identifier": 49455052
  },
  {
    "context": [
      "I managed to extract job name and status, now want to get date-ended.date ?",
      "jq '|[ .executions[] |select(.job.name != null) | select(.job.name) ]\n         | sort_by(.id)\n         | reverse \n         | .[0]\n         | \"\\(.status), \\(.job.name)\"' 1.json",
      "[.executions[] | select(.job.name != null)]\n     | sort_by(.id)\n     | reverse \n     | .[0]\n     | [.status, .job.name, .\"date-ended\".date]\n     | @csv",
      "This means the last filter of your jq program should be:\n\n    \"\\(.status), \\(.job.name), \\(.\"date-ended\".date)\""
    ],
    "utterance": "Extract the status, job name, and date-ended.date fields from the latest execution where job.name is not null, formatted as CSV.",
    "expressions": [
      "[.executions[] | select(.job.name != null)] | sort_by(.id) | reverse | .[0] | [.status, .job.name, .\"date-ended\".date] | @csv",
      "[.executions[] | select(.job.name != null)] | sort_by(.id) | reverse | .[0] | \"\\(.status), \\(.job.name), \\(.\"date-ended\".date)\""
    ],
    "data": [
      {
        "input": {
          "executions": [
            {
              "argstring": null,
              "date-ended": {
                "date": "2018-04-03T17:43:38Z",
                "unixtime": 1522777418397
              },
              "date-started": {
                "date": "2018-04-03T17:43:34Z",
                "unixtime": 1522777414646
              },
              "description": "",
              "executionType": "user",
              "failedNodes": [
                "172.30.61.88"
              ],
              "href": "http://172.30.61.88:4440/api/21/execution/126",
              "id": 126,
              "job": {
                "averageDuration": 4197,
                "description": "",
                "group": "",
                "href": "http://172.30.61.88:4440/api/21/job/271cbcec-5042-4d52-b794-ede2056b2ab8",
                "id": "271cbcec-5042-4d52-b794-ede2056b2ab8",
                "name": "aa",
                "permalink": "http://172.30.61.88:4440/project/demo/job/show/271cbcec-5042-4d52-b794-ede2056b2ab8",
                "project": "demo"
              },
              "permalink": "http://172.30.61.88:4440/project/demo/execution/show/126",
              "project": "demo",
              "status": "failed",
              "user": "administrator"
            }
          ]
        },
        "output": "\"failed\",\"aa\",\"2018-04-03T17:43:38Z\""
      }
    ],
    "identifier": 49637299
  },
  {
    "context": [
      "I have files which have N JSON objects and they are separated by comma (,)",
      "{\"a\":1},{\"b\":2},{\"c\":3},{\"d\":2},{\"e\":1},{\"f\":2} ...",
      "I would like to convert them into one JSON array with N objects using `jq`",
      "I tried jq -R 'split(\",\")' myfile.json but it gives me an array of N strings",
      "You are on the right track, you just need to map `fromjson` to the array, e.g.:",
      "jq -Rc 'split(\",\") | map(fromjson)' myfile.json",
      "Output:",
      "[{\"a\":1},{\"b\":2},{\"c\":3},{\"d\":2},{\"e\":1},{\"f\":2}]"
    ],
    "utterance": "Convert a file containing comma-separated JSON objects into a single array of objects.",
    "expressions": [
      "split(\",\") | map(fromjson)"
    ],
    "data": [
      {
        "input": "{\"a\":1},{\"b\":2},{\"c\":3},{\"d\":2},{\"e\":1},{\"f\":2}",
        "output": [
          {
            "a": 1
          },
          {
            "b": 2
          },
          {
            "c": 3
          },
          {
            "d": 2
          },
          {
            "e": 1
          },
          {
            "f": 2
          }
        ]
      }
    ],
    "identifier": 49645325
  },
  {
    "context": [
      "I have tried `jq '.module.data.deliverySummary_200648721592191#address'` but it just returns `null` instead of the part that I want above, how do I fix it ?",
      "You should add double-quotation-marks around the problematic property key like `'.module.data.\"deliverySummary_200648721592191#address\"'` for your case."
    ],
    "utterance": "Extract the value of the key deliverySummary_200648721592191#address from inside module.data.",
    "expressions": [
      ".module.data[\"deliverySummary_200648721592191#address\"]"
    ],
    "data": [
      {
        "input": {
          "module": {
            "data": {
              "deliverySummary_200648721592191#address": {
                "fields": {
                  "address": "MyAddress",
                  "consignee": "MyName",
                  "phone": "MyPhone",
                  "postCode": "",
                  "title": "Alamat Pengiriman \\r\\n"
                },
                "id": "200648721592191#address",
                "tag": "deliverySummary",
                "type": "biz"
              }
            }
          }
        },
        "output": {
          "fields": {
            "address": "MyAddress",
            "consignee": "MyName",
            "phone": "MyPhone",
            "postCode": "",
            "title": "Alamat Pengiriman \\r\\n"
          },
          "id": "200648721592191#address",
          "tag": "deliverySummary",
          "type": "biz"
        }
      }
    ],
    "identifier": 49646049
  },
  {
    "context": [
      "I would like to create n files that copy the JSON file but with a random correlationId and correlationDateTime.",
      "$ jq --arg cid \"foo\" --arg cdt \"bar\" '\n        .header.correlationContext.array[0]={\n            correlationId: $cid,\n            correlationDateTime: {string: $cdt}\n         }' tmp.json"
    ],
    "utterance": "Create copies of the input where header.correlationContext.array[0].correlationId and header.correlationContext.array[0].correlationDateTime.string are replaced by provided values.",
    "expressions": [
      ".header.correlationContext.array[0]={correlationId: $cid, correlationDateTime: {string: $cdt}}"
    ],
    "data": [
      {
        "input": {
          "header": {
            "uuid": "c578592a-a751-4993-9060-53f488597e59",
            "timestamp": 1522938800,
            "productionDateTime": "2018-04-05T14:33:20.000+00:00",
            "producers": {
              "operator": null,
              "application": {
                "com.example": {
                  "id": {
                    "string": "1"
                  },
                  "name": {
                    "string": "Test"
                  }
                }
              },
              "station": null,
              "equipment": null,
              "partner": null,
              "flow": null
            },
            "correlationContext": {
              "array": [
                {
                  "correlationId": "98440498-3104-479e-9c99-f4449ba8f4b6",
                  "correlationDateTime": {
                    "string": "2018-04-05T14:30:39.000+00:00"
                  }
                }
              ]
            }
          }
        },
        "output": {
          "header": {
            "uuid": "c578592a-a751-4993-9060-53f488597e59",
            "timestamp": 1522938800,
            "productionDateTime": "2018-04-05T14:33:20.000+00:00",
            "producers": {
              "operator": null,
              "application": {
                "com.example": {
                  "id": {
                    "string": "1"
                  },
                  "name": {
                    "string": "Test"
                  }
                }
              },
              "station": null,
              "equipment": null,
              "partner": null,
              "flow": null
            },
            "correlationContext": {
              "array": [
                {
                  "correlationId": "foo",
                  "correlationDateTime": {
                    "string": "bar"
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 49675733
  },
  {
    "context": [
      "Is any option that i can convert shell `last` output to json",
      "eg: last output",
      "test   pts/0        1.1.1.1     Wed Jun 21 14:28 - 20:19  (05:51)",
      "jq -R '\n    split(\"[[:space:]]+\"; \"g\")\n    | select(length > 2) | select(.[0] != \"\")\n    | { \"name\":    (.[0]),\n        \"console\": (.[1]),\n        \"ip\":      (.[2]),\n        \"day\":     (.[3])\n      }\n' < <(last)",
      "Another option to consider is using regex capture variables.  Consider for example:",
      "capture(\"(?<name>^[^ ]+) +(?<token>[^ ]+) +(?<numeric>[0-9.]+) +(?<range>[^()]+)  +(?<time>.*)\")",
      "the output would be:",
      "{\n  \"name\": \"test\",\n  \"token\": \"pts/0\",\n  \"numeric\": \"1.1.1.1\",\n  \"range\": \"Wed Jun 21 14:28 - 20:19\",\n  \"time\": \"(05:51)\"\n}"
    ],
    "utterance": "Convert each line of last command output containing name, pts, IP, range, and time fields into objects with keys for each field and their corresponding values.",
    "expressions": [
      "split(\"[[:space:]]+\"; \"g\") | select(length > 2) | select(.[0] != \"\") | { \"name\": (.[0]), \"console\": (.[1]), \"ip\": (.[2]), \"day\": (.[3]) }",
      "capture(\"(?<name>^[^ ]+) +(?<token>[^ ]+) +(?<numeric>[0-9.]+) +(?<range>[^()]+)  +(?<time>.*)\")"
    ],
    "data": [
      {
        "input": "test   pts/0        1.1.1.1     Wed Jun 21 14:28 - 20:19  (05:51)",
        "output": {
          "name": "test",
          "token": "pts/0",
          "numeric": "1.1.1.1",
          "range": "Wed Jun 21 14:28 - 20:19",
          "time": "(05:51)"
        }
      }
    ],
    "identifier": 49736418
  },
  {
    "context": [
      "And I want to extract `Info` in `shippingInfo_` > `fields` > `trackingList` So the output that I want is like this:",
      "Status One",
      "Status Two",
      "Status Three",
      "Status Four",
      "The string after `shippingInfo_` is always random, how do I extract it with jq?",
      "to_entries[]\n| select(.key |  startswith(\"shippingInfo_\"))\n| .value\n| .fields.trackingList[]\n| .info",
      "def dot(s):\n  to_entries[] | select(.key|test(s)) | .value ;\n\ndot(\"^shippingInfo_\")\n| .fields.trackingList[]\n| .info"
    ],
    "utterance": "Extract all values at fields.trackingList[].info for every top-level key that starts with shippingInfo_.",
    "expressions": [
      "to_entries[] | select(.key |  startswith(\"shippingInfo_\")) | .value | .fields.trackingList[] | .info",
      "def dot(s): to_entries[] | select(.key|test(s)) | .value ; dot(\"^shippingInfo_\") | .fields.trackingList[] | .info",
      "dot(\"^shippingInfo_\").fields.trackingList[].info"
    ],
    "data": [
      {
        "input": {
          "root_200888546292191": {
            "fields": {
              "buyerId": "31392191"
            },
            "id": "200718546292191",
            "tag": "root",
            "type": "biz"
          },
          "shippingInfo_#package#OF04472002179150#WAREHOUSE_ACCEPTED": {
            "fields": {
              "delivery": {
                "createdAt": "Sen 09 Apr - Rab 11 Apr",
                "desc": "Standar",
                "email": null,
                "method": "Standard",
                "status": "info"
              },
              "statusMap": {
                "active": "Dalam proses",
                "all": [
                  "Dalam proses",
                  "Dalam pengiriman",
                  "Telah diterima"
                ]
              },
              "trackingList": [
                {
                  "info": "Status One",
                  "updatedAt": "05 Apr 2018 - 11:00"
                },
                {
                  "info": "Status Two",
                  "updatedAt": "05 Apr 2018 - 11:00"
                }
              ]
            },
            "id": "#package#OF04472002179150#WAREHOUSE_ACCEPTED",
            "tag": "shippingInfo",
            "type": "biz"
          },
          "shippingInfo_#package#AAAAAAAAAAAAA#NOT_WAREHOUSE_ACCEPTED": {
            "fields": {
              "delivery": {
                "createdAt": "Sen 09 Apr - Rab 11 Apr",
                "desc": "Standar",
                "email": null,
                "method": "Standard",
                "status": "info"
              },
              "statusMap": {
                "active": "Dalam proses",
                "all": [
                  "Dalam proses",
                  "Dalam pengiriman",
                  "Telah diterima"
                ]
              },
              "trackingList": [
                {
                  "info": "Status Three",
                  "updatedAt": "05 Apr 2018 - 11:00"
                },
                {
                  "info": "Status Four",
                  "updatedAt": "05 Apr 2018 - 11:00"
                }
              ]
            },
            "id": "#package#AAAAAAAAAAAAA#NOT_WAREHOUSE_ACCEPTED",
            "tag": "shippingInfo",
            "type": "biz"
          },
          "login_200718577292191": {
            "fields": {
              "buyerEmail": "myemail@gmail.com",
              "buyerName": "myname"
            },
            "id": "200718522292191",
            "tag": "login",
            "type": "biz"
          }
        },
        "output": [
          "Status One",
          "Status Two",
          "Status Three",
          "Status Four"
        ]
      }
    ],
    "identifier": 49665137
  },
  {
    "context": [
      "I would like to get back a single json object where the output names are the keys and the values are the output values. Like in this example...",
      "{\n  \"elb_dns_name\": \"web-elb-1019323532.us-east-1.elb.amazonaws.com\",\n  \"dns_name\": \"web-elb-1019323532.us-east-1.elb.amazonaws.com\",\n  \"security_group_id\": \"sg-5a677425\",\n  \"web_instance_ids\": \"i-03676fa6ba43fbb9f,i-09f51a313146856cd\",\n  \"web_public_ips\": \"34.207.194.186,34.203.236.205\"\n}",
      "This is what I used `.modules | map(.outputs | to_entries[] | {(.key): .value.value}) | add`",
      "Using `map_values` produces a simpler (or at least shorter) filter, and might be more efficient:\n\n    .modules | map(.outputs | map_values(.value) ) | add"
    ],
    "utterance": "Return a single object mapping all output names in modules to their corresponding values.",
    "expressions": [
      ".modules | map(.outputs | to_entries[] | {(.key): .value.value}) | add",
      ".modules | map(.outputs | map_values(.value) ) | add"
    ],
    "data": [
      {
        "input": {
          "version": 3,
          "terraform_version": "0.9.3",
          "serial": 0,
          "lineage": "ae1f2572-8fa6-4977-be73-3deac7529eff",
          "modules": [
            {
              "path": [
                "root"
              ],
              "outputs": {
                "elb_dns_name": {
                  "sensitive": false,
                  "type": "string",
                  "value": "web-elb-1019323532.us-east-1.elb.amazonaws.com"
                }
              },
              "resources": {},
              "depends_on": []
            },
            {
              "path": [
                "root",
                "elb"
              ],
              "outputs": {
                "dns_name": {
                  "sensitive": false,
                  "type": "string",
                  "value": "web-elb-1019323532.us-east-1.elb.amazonaws.com"
                }
              },
              "depends_on": []
            },
            {
              "path": [
                "root",
                "sg"
              ],
              "outputs": {
                "security_group_id": {
                  "sensitive": false,
                  "type": "string",
                  "value": "sg-5a677425"
                }
              },
              "depends_on": []
            },
            {
              "path": [
                "root",
                "web"
              ],
              "outputs": {
                "web_instance_ids": {
                  "sensitive": false,
                  "type": "string",
                  "value": "i-03676fa6ba43fbb9f,i-09f51a313146856cd"
                },
                "web_public_ips": {
                  "sensitive": false,
                  "type": "string",
                  "value": "34.207.194.186,34.203.236.205"
                }
              },
              "depends_on": []
            }
          ]
        },
        "output": {
          "elb_dns_name": "web-elb-1019323532.us-east-1.elb.amazonaws.com",
          "dns_name": "web-elb-1019323532.us-east-1.elb.amazonaws.com",
          "security_group_id": "sg-5a677425",
          "web_instance_ids": "i-03676fa6ba43fbb9f,i-09f51a313146856cd",
          "web_public_ips": "34.207.194.186,34.203.236.205"
        }
      }
    ],
    "identifier": 49680434
  },
  {
    "context": [
      "And I want to remove all objects with value unset ```\"\"```",
      "I have such filter but it prints also ```null``` - how to rid it of?",
      "$ jq 'del(select(.value == \"\"))' /tmp/intest",
      "Just revert the logic:",
      "jq 'select(.value!=\"\")'"
    ],
    "utterance": "Filter to keep only objects where the value field is not an empty string.",
    "expressions": [
      "select(.value!=\"\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": 381,
            "name": "Module",
            "value": "C-A",
            "locked": false
          },
          {
            "id": 381,
            "name": "Module",
            "value": "",
            "locked": false
          },
          {
            "id": 381,
            "name": "Module",
            "value": "",
            "locked": false
          }
        ],
        "output": [
          {
            "id": 381,
            "name": "Module",
            "value": "C-A",
            "locked": false
          }
        ]
      }
    ],
    "identifier": 49752871
  },
  {
    "context": [
      "Is it possible to modify/replace array elements while grouping by a specific key (`.[].Parameter.Id`) such that this array:\r\n\r\n    [{\r\n    \t\"Id\": 48,\r\n    \t\"Parameter\": {\r\n    \t\t\"Id\": 17\r\n    \t}\r\n    }, {\r\n    \t\"Id\": 196,\r\n    \t\"Parameter\": {\r\n    \t\t\"Id\": 17\r\n    \t}\r\n    }]\r\n\r\nbecomes this:\r\n\r\n    [\r\n       {\r\n        \"p17\": [48, 196]\r\n       }\r\n    ]",
      "What I want to achieve is this:\r\n\r\n    [{\r\n    \t\"Id\": 78,\r\n    \t\"PromotionType\": 2,\r\n    \t\"Amount\": \"100\",\r\n    \t\"UpperLimit\": null,\r\n    \t\"Variables\": [{\r\n    \t\t\"p30\": [100]\r\n    \t}]\r\n    }, {\r\n    \t\"Id\": 84,\r\n    \t\"PromotionType\": 2,\r\n    \t\"Amount\": null,\r\n    \t\"UpperLimit\": null,\r\n    \t\"Variables\": [{\r\n    \t\t\"p17\": [48, 196]\r\n    \t}, {\r\n    \t\t\"p21\": [59, 60, 62]\r\n    \t}]\r\n    }, {\r\n    \t\"Id\": 59,\r\n    \t\"PromotionType\": 2,\r\n    \t\"Amount\": \"666.6\",\r\n    \t\"UpperLimit\": null,\r\n    \t\"Variables\": [{\r\n    \t\t\"p8\": [96]\r\n    \t}, {\r\n    \t\t\"p17\": [47]\r\n    \t}]\r\n    }]",
      "jq 'map(.Variables \r\n            |= (group_by(.Parameter.Id) \r\n                | map((\"p\" + (.[0].Parameter.Id | tostring)) as $pid \r\n                      | { ($pid) : map(.Id) }\r\n                  )\r\n               )\r\n        )' input.json"
    ],
    "utterance": "Group each object's Variables array by Parameter.Id and replace with an array of objects where each key is 'p' plus the Parameter.Id and the value is an array of the grouped Id values.",
    "expressions": [
      "map(.Variables |= (group_by(.Parameter.Id) | map((\"p\" + (.[0].Parameter.Id | tostring)) as $pid | { ($pid) : map(.Id) })))"
    ],
    "data": [
      {
        "input": [
          {
            "Id": 78,
            "PromotionType": 2,
            "Amount": "100",
            "UpperLimit": null,
            "Variables": [
              {
                "Id": 100,
                "Parameter": {
                  "Id": 30
                }
              }
            ]
          },
          {
            "Id": 84,
            "PromotionType": 2,
            "Amount": null,
            "UpperLimit": null,
            "Variables": [
              {
                "Id": 48,
                "Parameter": {
                  "Id": 17
                }
              },
              {
                "Id": 196,
                "Parameter": {
                  "Id": 17
                }
              },
              {
                "Id": 59,
                "Parameter": {
                  "Id": 21
                }
              },
              {
                "Id": 60,
                "Parameter": {
                  "Id": 21
                }
              },
              {
                "Id": 62,
                "Parameter": {
                  "Id": 21
                }
              }
            ]
          },
          {
            "Id": 59,
            "PromotionType": 2,
            "Amount": "666.6",
            "UpperLimit": null,
            "Variables": [
              {
                "Id": 96,
                "Parameter": {
                  "Id": 8
                }
              },
              {
                "Id": 47,
                "Parameter": {
                  "Id": 17
                }
              }
            ]
          }
        ],
        "output": [
          {
            "Id": 78,
            "PromotionType": 2,
            "Amount": "100",
            "UpperLimit": null,
            "Variables": [
              {
                "p30": [
                  100
                ]
              }
            ]
          },
          {
            "Id": 84,
            "PromotionType": 2,
            "Amount": null,
            "UpperLimit": null,
            "Variables": [
              {
                "p17": [
                  48,
                  196
                ]
              },
              {
                "p21": [
                  59,
                  60,
                  62
                ]
              }
            ]
          },
          {
            "Id": 59,
            "PromotionType": 2,
            "Amount": "666.6",
            "UpperLimit": null,
            "Variables": [
              {
                "p8": [
                  96
                ]
              },
              {
                "p17": [
                  47
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 49748060
  },
  {
    "context": [
      "There is bunch of carl's, but only 2 of them are duplicates - name:carl & height:180cm.",
      "For example I need to average amount of his wifes and sum his sons.",
      "The grouping can be achieved by `group_by/1` using [.name,.height] as the grouping criterion:",
      "def sum(f): map(f) | add;",
      "def average(f): sum(f) / length;",
      "def consolidate:\n  .[0]\n  + {wifes: average(.wifes)}\n  + {sons:  sum(.sons) } ;",
      ".people\n| group_by([.name,.height])\n| map(consolidate)"
    ],
    "utterance": "Group objects by both name and height, then average the wifes field and sum the sons field within each group.",
    "expressions": [
      "def sum(f): map(f) | add;\ndef average(f): sum(f) / length;\ndef consolidate: .[0] + {wifes: average(.wifes)} + {sons: sum(.sons)}; .people | group_by([.name,.height]) | map(consolidate)"
    ],
    "data": [
      {
        "input": {
          "some": "very",
          "random": 0.228,
          "stuff": 31337,
          "people": [
            {
              "name": "carl",
              "height": "180cm",
              "wifes": 1,
              "sons": 0
            },
            {
              "name": "charlie",
              "height": "166cm",
              "wifes": 0,
              "sons": 2
            },
            {
              "name": "carl",
              "height": "180cm",
              "wifes": 1,
              "sons": 1
            },
            {
              "name": "carl",
              "height": "195cm",
              "wifes": 1.95,
              "sons": 12
            }
          ]
        },
        "output": [
          {
            "name": "carl",
            "height": "180cm",
            "wifes": 1,
            "sons": 1
          },
          {
            "name": "carl",
            "height": "195cm",
            "wifes": 1.95,
            "sons": 12
          },
          {
            "name": "charlie",
            "height": "166cm",
            "wifes": 0,
            "sons": 2
          }
        ]
      }
    ],
    "identifier": 49759823
  },
  {
    "context": [
      "I need to extract with jq filter following output:\r\n\r\n```id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1```\r\n\r\nAll objects having pname beginning with ```#``` in ```xstart``` sections should be ignored from processig.",
      "jq -r '\"id:\" + (.id|tostring) + \" mname:\" + .mname \r\n           + \" target:\" + (.attrib[] | select(.name == \"target\").value) \r\n           + \" pname:\" + (.xstart[] | select(.pname | startswith(\"#\") | not) as $x | $x.pname \r\n           + \" xnode:\" + ($x.attrib[] | select(.name==\"xnode\").value))' input.json",
      "The output:\r\n\r\n    id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1"
    ],
    "utterance": "Extract fields id, mname, target (where name==\"target\"), pname, and xnode (where name==\"xnode\") for each xstart entry whose pname does not start with '#', formatting the result as a single line: id:<id> mname:<mname> target:<target> pname:<pname> xnode:<xnode>.",
    "expressions": [
      "\"id:\" + (.id|tostring) + \" mname:\" + .mname + \" target:\" + (.attrib[] | select(.name == \"target\").value) + \" pname:\" + (.xstart[] | select(.pname | startswith(\"#\") | not) as $x | $x.pname + \" xnode:\" + ($x.attrib[] | select(.name==\"xnode\").value))"
    ],
    "data": [
      {
        "input": {
          "id": 1022,
          "mname": "P1",
          "attrib": [
            {
              "id": 1,
              "name": "log",
              "value": "1"
            },
            {
              "id": 622,
              "name": "target",
              "value": "host.domain.com"
            },
            {
              "id": 623,
              "name": "iddle",
              "value": "30"
            }
          ],
          "xstart": [
            {
              "id": 1021,
              "pname": "P1A",
              "attrib": [
                {
                  "id": 530,
                  "name": "xnode",
                  "value": "1"
                },
                {
                  "id": 498,
                  "name": "remote",
                  "value": "1"
                }
              ]
            },
            {
              "id": 1022,
              "pname": "#P1C",
              "attrib": [
                {
                  "id": 530,
                  "name": "xnode",
                  "value": "2"
                },
                {
                  "id": 498,
                  "name": "remote",
                  "value": "1"
                }
              ]
            }
          ]
        },
        "output": "id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1"
      }
    ],
    "identifier": 49756994
  },
  {
    "context": [
      "I\u2019d like to remove from the array the object that match the test `a/b/*` against `path` property",
      "jq '.[]|select(.path|startswith(\"a/b/\")|not)' file.json"
    ],
    "utterance": "Remove elements from an array where the object's path property starts with 'a/b/'.",
    "expressions": [
      ".[] | select(.path | startswith(\"a/b/\") | not)"
    ],
    "data": [
      {
        "input": [
          {
            "path": "a/b/v1-another"
          },
          {
            "path": "a/b/v1"
          }
        ]
      }
    ],
    "identifier": 49795109
  },
  {
    "context": [
      "I have a json file, example.json:\r\n\r\n    [\r\n      [\r\n        \"126\",\r\n        1522767000\r\n      ],\r\n      [\r\n        \"122\",\r\n        1522859400\r\n      ],\r\n      [\r\n        \"126\",\r\n        1523348520\r\n      ]\r\n    ]",
      "and would like to add multiple parent items with the desired output:\r\n\r\n    {\r\n      \"target\": \"Systolic\",\r\n      \"datapoints\": [\r\n        [\r\n          \"126\",\r\n          1522767000\r\n        ],\r\n        [\r\n          \"122\",\r\n          1522859400\r\n        ],\r\n        [\r\n          \"126\",\r\n          1523348520\r\n        ]\r\n      ]\r\n    }",
      "jq '{target: \"Systolic\", datapoints: .}' example.json"
    ],
    "utterance": "Wrap the array in an object with the key 'target' set to 'Systolic' and the key 'datapoints' set to the original array.",
    "expressions": [
      "{target: \"Systolic\", datapoints: .}"
    ],
    "data": [
      {
        "input": [
          [
            "126",
            1522767000
          ],
          [
            "122",
            1522859400
          ],
          [
            "126",
            1523348520
          ]
        ],
        "output": {
          "target": "Systolic",
          "datapoints": [
            [
              "126",
              1522767000
            ],
            [
              "122",
              1522859400
            ],
            [
              "126",
              1523348520
            ]
          ]
        }
      }
    ],
    "identifier": 49780588
  },
  {
    "context": [
      "to increment and populate the new field `Down_Count` by grouping by `organizationId`. I can have multiple records with same `organizationId`. Hence, the count should be incremented that number of times subject to status `DOWN`.",
      "Merge `server` and `status` fields. For example `\"server\":\"server1\", \"status\":\"down\"` should come as `server1:down` directly in final output.",
      "Lets assume I know the key name I want to add. In the final output,  I have added only `\"somekey2\" : \"somevalue2\"`",
      "jq 'group_by(.organizationId) \n    | map(reduce .[] as $o ({\"Down_Count\" : 0};\n              if $o[\"status\"] == \"DOWN\" then .Down_Count += 1 else . end\n              | . + { ($o[\"server\"]) : $o[\"status\"],\n                          \"organizationId\" : $o[\"organizationId\"] }\n          ))'",
      "jq --argjson keys '[\"somekey2\"]' -f program.jq input.json",
      "group_by(.organizationId) | map(\n    reduce ([., [range(length)]] | transpose[]) as [$o,$i] (\n        {\n            organizationId: .[0].organizationId,\n            Down_Count: (map(select(.status==\"DOWN\")) | length)\n        };\n        reduce $keys[] as $k (\n            .[\"server\\($i+1)\"] = $o.status;\n            if $o | has($k) then .[$k] = $o[$k] else . end\n        )\n    )\n)"
    ],
    "utterance": "For each unique organizationId, create a single object with keys for each server having its status as value, a Down_Count field counting entries with status DOWN, and include only the specified extra key(s) such as somekey2 if present.",
    "expressions": [
      "group_by(.organizationId) \n| map(reduce .[] as $o ({\"Down_Count\" : 0};\n      if $o[\"status\"] == \"DOWN\" then .Down_Count += 1 else . end\n      | . + { ($o[\"server\"]) : $o[\"status\"],\n               \"organizationId\" : $o[\"organizationId\"] }\n      | if $o | has(\"somekey2\") then . + {\"somekey2\": $o[\"somekey2\"]} else . end\n))",
      "group_by(.organizationId) | map(\n    reduce ([., [range(length)]] | transpose[]) as [$o,$i] (\n        {\n            organizationId: .[0].organizationId,\n            Down_Count: (map(select(.status==\"DOWN\")) | length)\n        };\n        reduce $keys[] as $k (\n            .[(\"server\" + ($i+1|tostring))] = $o.status;\n            if $o | has($k) then .[$k] = $o[$k] else . end\n        )\n    )\n)"
    ],
    "data": [
      {
        "input": [
          {
            "organizationId": "org1",
            "status": "UP",
            "server": "server1",
            "somekey1": "somevalue1"
          },
          {
            "organizationId": "org1",
            "status": "DOWN",
            "server": "server2",
            "somekey2": "somevalue2"
          },
          {
            "organizationId": "org1",
            "status": "DOWN",
            "server": "server3"
          },
          {
            "organizationId": "org2",
            "server": "server1",
            "status": "UP",
            "somekey2": "somevalue2"
          },
          {
            "organizationId": "org2",
            "server": "server2",
            "status": "UP",
            "somekey4": "somevalue4"
          }
        ],
        "output": [
          {
            "organizationId": "org1",
            "server1": "UP",
            "server2": "DOWN",
            "server3": "DOWN",
            "Down_Count": 2,
            "somekey2": "somevalue2"
          },
          {
            "organizationId": "org2",
            "server1": "UP",
            "server2": "UP",
            "Down_Count": 0,
            "somekey2": "somevalue2"
          }
        ]
      }
    ],
    "identifier": 49647815
  },
  {
    "context": [
      "to get the list of first name, I have to write:",
      "cat x.json | jq '.title[].type[].properties.firstname'",
      "is there a shorter way to get the first name? Instead of having to write the whole line of objects?",
      "Also is there a way to list more than just the first name, for example first and last name?",
      "cat x.json | jq '.[].firstName'",
      "$ jq -c '.[] | [.firstName, .lastName]' x.json"
    ],
    "utterance": "Extract the first name and last name for each person within an array of person objects.",
    "expressions": [
      ".[].firstName",
      ".[] | [.firstName, .lastName]"
    ],
    "data": [
      {
        "input": [
          {
            "firstName": "sin",
            "lastName": "minim sint labore"
          },
          {
            "firstName": "mun",
            "lastName": "minim sint labore"
          }
        ],
        "output": [
          [
            "sin",
            "minim sint labore"
          ],
          [
            "mun",
            "minim sint labore"
          ]
        ]
      }
    ],
    "identifier": 49808009
  },
  {
    "context": [
      "I have to select objects in an array according a test pattern",
      "I apply the following command:\n\n    jq '.[] | select(.path | test(\"a/b\") | not)'",
      "My problem is that the result is not anymore an array but a list of objects.",
      "By starting the pipeline with `.[]`, you are converting the array into a stream.  You could \"reconstitute\" the array by wrapping the entire jq expression in square brackets (i.e. `[ .... ]`); or you could avoid using `.[]` in the first place by using `map( select(...) )`."
    ],
    "utterance": "Filter an array to exclude objects whose 'path' field matches the pattern 'a/b', and return the result as an array.",
    "expressions": [
      "[.[] | select(.path | test(\"a/b\") | not)]",
      "map(select(.path | test(\"a/b\") | not))"
    ],
    "data": [
      {
        "input": [
          {
            "path": "a/b"
          },
          {
            "path": "a/b/c"
          },
          {
            "path": "a/c"
          },
          {
            "path": "a/d"
          }
        ],
        "output": [
          {
            "path": "a/c"
          },
          {
            "path": "a/d"
          }
        ]
      }
    ],
    "identifier": 49811280
  },
  {
    "context": [
      "As stated in the sample output, if any object doesn\u2019t present, then they should come as \"-\".",
      "jq '{domain: \"-\", apiname: \"-\"} as $o \n    | map([.tags[] | .value | split(\":\") | {(.[0]) : .[1]}] | add | $o + .)' input.json",
      "\"The output:\\n\\n    [\\n      {\\n        \\\"domain\\\": \\\"sourcing\\\",\\n        \\\"apiname\\\": \\\"src1\\\"\\n      },\\n      {\\n        \\\"domain\\\": \\\"-\\\",\\n        \\\"apiname\\\": \\\"fin1\\\"\\n      },\\n      {\\n        \\\"domain\\\": \\\"fin1\\\",\\n        \\\"apiname\\\": \\\"-\\\"\\n      }\\n    ]\"",
      "map(\n    reduce (.tags[].value | split(\":\")) as [$k,$v] (\n        {domain:\"-\",apiname:\"-\"};\n        .[$k] = $v\n    )\n)",
      "{domain:\"-\", apiname:\"-\"} as $default\n| map([.tags[].value\n       | capture(\"(?<k>[^:]*):(?<v>.*)\")\n       | {(.k): .v} ]\n      | add\n      | $default + .)"
    ],
    "utterance": "For each object, extract the values after 'domain:' and 'apiname:' from any 'tags' entry, and output both keys with '-' if missing.",
    "expressions": [
      "{domain: \"-\", apiname: \"-\"} as $o | map([.tags[] | .value | split(\":\") | {(.[0]) : .[1]}] | add | $o + .)",
      "map(reduce (.tags[].value | split(\":\")) as [$k,$v] ({domain:\"-\",apiname:\"-\"}; .[$k] = $v))",
      "{domain:\"-\", apiname:\"-\"} as $default | map([.tags[].value | capture(\"(?<k>[^:]*):(?<v>.*)\") | {(.k): .v} ] | add | $default + .)"
    ],
    "data": [
      {
        "input": [
          {
            "tags": [
              {
                "value": "domain:sourcing"
              },
              {
                "value": "apiname:src1"
              }
            ]
          },
          {
            "tags": [
              {
                "value": "apiname:fin1"
              }
            ]
          },
          {
            "tags": [
              {
                "value": "domain:fin1"
              }
            ]
          }
        ],
        "output": [
          {
            "domain": "sourcing",
            "apiname": "src1"
          },
          {
            "domain": "-",
            "apiname": "fin1"
          },
          {
            "domain": "fin1",
            "apiname": "-"
          }
        ]
      }
    ],
    "identifier": 49800086
  },
  {
    "context": [
      "I use jq 1.5 under Windows 10 and got now an error with a json Transformation. I use following jq command: ...",
      "I use a second command to manipulate the Arrival/departue object: ... jq.exe \".[].arrival |= todateiso8601 | .[].departure |= todateiso8601\" ...",
      "On the new system i got following error: JQ: Invalid numeric literal at line 1, column 3.",
      "the input JSON is an array, so presumably you want to use map(...) rather than [...]"
    ],
    "utterance": "Convert the arrival and departure fields in every object of an array to ISO 8601 date strings.",
    "expressions": [
      "map(.arrival |= todateiso8601 | .departure |= todateiso8601)"
    ],
    "identifier": 49817756
  },
  {
    "context": [
      "$ jq --arg value_a0 1.1.1.1 --arg value_b0 81 --arg value_a1 2.2.2.2 --arg value_b1 82 --arg value_a2 3.3.3.3 --arg value_b2 83 '. | .nodes=[ .ip=$value_a0 | .port=$value_b0, .ip=$value_a1 | .port=$value_b1, .ip=$value_a2 | .port=$value_b2 ]' <<<'{}'",
      "I was hoping to get:\n\n    {\n      \"nodes\": [\n        {\n          \"ip\": \"1.1.1.1\",\n          \"port\": \"81\"\n        },\n        {\n          \"ip\": \"2.2.2.2\",\n          \"port\": \"82\"\n        },\n        {\n          \"ip\": \"3.3.3.3\",\n          \"port\": \"83\"\n        }\n      ]\n    }",
      "One way to accomplish what you want in the manner of your attempt would be as follows:\n\n    jq -n --arg value_a0 1.1.1.1 --arg value_b0 81 --arg value_a1 2.2.2.2 --arg value_b1 82 --arg value_a2 3.3.3.3 --arg value_b2 83 '\n      .nodes=[ {ip: $value_a0, port: $value_b0},\n               {ip: $value_a1, port: $value_b1},\n               {ip: $value_a2, port: $value_b2} ]'\n",
      "Using '=' one could similarly use the filter:\n\n    .nodes=[ (.ip=$value_a0 |.port=$value_b0),\n             (.ip=$value_a1 |.port=$value_b1), \n             (.ip=$value_a2 |.port=$value_b2) ]\n"
    ],
    "utterance": "Produce an object with a key 'nodes' whose value is an array of objects, each containing 'ip' and 'port' fields from specified variables ($value_a0/$value_b0, $value_a1/$value_b1, $value_a2/$value_b2).",
    "expressions": [
      ".nodes=[ {ip: $value_a0, port: $value_b0}, {ip: $value_a1, port: $value_b1}, {ip: $value_a2, port: $value_b2} ]",
      ".nodes=[ (.ip=$value_a0 | .port=$value_b0), (.ip=$value_a1 | .port=$value_b1), (.ip=$value_a2 | .port=$value_b2) ]"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "nodes": [
            {
              "ip": "1.1.1.1",
              "port": "81"
            },
            {
              "ip": "2.2.2.2",
              "port": "82"
            },
            {
              "ip": "3.3.3.3",
              "port": "83"
            }
          ]
        }
      }
    ],
    "identifier": 49810143
  },
  {
    "context": [
      "The field I want to be changed is called \"Stock\" and if the value is \"Add to cart\" or just \"add\" I want this replaced with \"In stock\".",
      "the points of clarification that would be helpful are whether the input is an object, and whether the relevant keys all occur within the top-most level object(s).",
      "pay particular attention to the `to_entries`, `from-entries`, and `with_entries` filters."
    ],
    "utterance": "Replace the value of the field named Stock with In stock if its current value is Add to cart or add.",
    "expressions": [
      ".Stock |= if . == \"Add to cart\" or . == \"add\" then \"In stock\" else . end",
      "with_entries(if .key == \"Stock\" and (.value == \"Add to cart\" or .value == \"add\") then .value = \"In stock\" else . end)"
    ],
    "data": [
      {
        "input": {
          "Stock": "Add to cart"
        },
        "output": {
          "Stock": "In stock"
        }
      },
      {
        "input": {
          "Stock": "add"
        },
        "output": {
          "Stock": "In stock"
        }
      },
      {
        "input": {
          "Stock": "Sold out"
        },
        "output": {
          "Stock": "Sold out"
        }
      }
    ],
    "identifier": 49843350
  },
  {
    "context": [
      "I want to get the t1, t2, t3 values from the field 'name'\u00a0and then assign the values to a array which is variable so that I can refer to the array and do a POST.",
      "\"name\" is not a top-level key.  Consider instead:",
      "$ jq '.items[] | .name' good.json",
      "\"t1\"",
      "\"t2\"",
      "\"t3\""
    ],
    "utterance": "Extract all values of the field 'name' from each object inside the 'items' array.",
    "expressions": [
      ".items[] | .name",
      ".items[].name",
      "[.items[].name]"
    ],
    "data": [
      {
        "input": {
          "kind": "tm:ltm:virtual:virtualcollectionstate",
          "selfLink": "https://localhost/mgmt/tm/ltm/virtual?ver=12.0.0",
          "items": [
            {
              "kind": "tm:ltm:virtual:virtualstate",
              "name": "t1",
              "partition": "Common",
              "fullPath": "/Common/t1",
              "generation": 124,
              "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~t1?ver=12.0.0",
              "addressStatus": "yes",
              "autoLasthop": "default",
              "cmpEnabled": "yes",
              "connectionLimit": 0,
              "destination": "/Common/3.3.3.3:80",
              "enabled": true,
              "gtmScore": 0,
              "ipProtocol": "tcp",
              "mask": "255.255.255.255",
              "mirror": "disabled",
              "mobileAppTunnel": "disabled",
              "nat64": "disabled",
              "rateLimit": "disabled",
              "rateLimitDstMask": 0,
              "rateLimitMode": "object",
              "rateLimitSrcMask": 0,
              "serviceDownImmediateAction": "none",
              "source": "0.0.0.0/0",
              "sourceAddressTranslation": {
                "type": "none"
              },
              "sourcePort": "preserve",
              "synCookieStatus": "not-activated",
              "translateAddress": "enabled",
              "translatePort": "enabled",
              "vlansDisabled": true,
              "vsIndex": 21,
              "policiesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t1/policies?ver=12.0.0",
                "isSubcollection": true
              },
              "profilesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t1/profiles?ver=12.0.0",
                "isSubcollection": true
              }
            },
            {
              "kind": "tm:ltm:virtual:virtualstate",
              "name": "t2",
              "partition": "Common",
              "fullPath": "/Common/t2",
              "generation": 178,
              "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~t2?ver=12.0.0",
              "addressStatus": "yes",
              "autoLasthop": "default",
              "cmpEnabled": "yes",
              "connectionLimit": 0,
              "destination": "/Common/4.4.4.4:80",
              "enabled": true,
              "gtmScore": 0,
              "ipProtocol": "tcp",
              "mask": "255.255.255.255",
              "mirror": "disabled",
              "mobileAppTunnel": "disabled",
              "nat64": "disabled",
              "rateLimit": "disabled",
              "rateLimitDstMask": 0,
              "rateLimitMode": "object",
              "rateLimitSrcMask": 0,
              "serviceDownImmediateAction": "none",
              "source": "0.0.0.0/0",
              "sourceAddressTranslation": {
                "type": "none"
              },
              "sourcePort": "preserve",
              "synCookieStatus": "not-activated",
              "translateAddress": "enabled",
              "translatePort": "enabled",
              "vlansDisabled": true,
              "vsIndex": 22,
              "policiesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t2/policies?ver=12.0.0",
                "isSubcollection": true
              },
              "profilesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t2/profiles?ver=12.0.0",
                "isSubcollection": true
              }
            },
            {
              "kind": "tm:ltm:virtual:virtualstate",
              "name": "t3",
              "partition": "Common",
              "fullPath": "/Common/t3",
              "generation": 179,
              "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~t3?ver=12.0.0",
              "addressStatus": "yes",
              "autoLasthop": "default",
              "cmpEnabled": "yes",
              "connectionLimit": 0,
              "destination": "/Common/5.5.5.5:80",
              "enabled": true,
              "gtmScore": 0,
              "ipProtocol": "tcp",
              "mask": "255.255.255.255",
              "mirror": "disabled",
              "mobileAppTunnel": "disabled",
              "nat64": "disabled",
              "rateLimit": "disabled",
              "rateLimitDstMask": 0,
              "rateLimitMode": "object",
              "rateLimitSrcMask": 0,
              "serviceDownImmediateAction": "none",
              "source": "0.0.0.0/0",
              "sourceAddressTranslation": {
                "type": "none"
              },
              "sourcePort": "preserve",
              "synCookieStatus": "not-activated",
              "translateAddress": "enabled",
              "translatePort": "enabled",
              "vlansDisabled": true,
              "vsIndex": 23,
              "policiesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t3/policies?ver=12.0.0",
                "isSubcollection": true
              },
              "profilesReference": {
                "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~t3/profiles?ver=12.0.0",
                "isSubcollection": true
              }
            }
          ]
        },
        "output": [
          "t1",
          "t2",
          "t3"
        ]
      }
    ],
    "identifier": 49637556
  },
  {
    "context": [
      "I am trying to trying to transform\r\n\r\n    {\r\n      \"login\": \"username\",\r\n      \"emails\": [\r\n        \"email_1@example.com\",\r\n        \"email_2@example.com\"\r\n      ]\r\n    }\r\n\r\ninto\r\n\r\n    [\r\n      {\r\n        \"email\": \"email_1@example.com\",\r\n        \"login\": \"username\"\r\n      },\r\n      {\r\n        \"email\": \"email_2@example.com\",\r\n        \"login\": \"username\"\r\n      }\r\n    ]",
      "jq '.login as $uname | .emails | map({email: ., login: $uname})' input.json",
      "[{login, email: .emails[]}]"
    ],
    "utterance": "Transform an object with fields 'login' and 'emails' (an array) into an array of objects with 'email' and 'login', pairing each email with the login.",
    "expressions": [
      ".login as $uname | .emails | map({email: ., login: $uname})",
      "[{login, email: .emails[]}]"
    ],
    "data": [
      {
        "input": {
          "login": "username",
          "emails": [
            "email_1@example.com",
            "email_2@example.com"
          ]
        },
        "output": [
          {
            "email": "email_1@example.com",
            "login": "username"
          },
          {
            "email": "email_2@example.com",
            "login": "username"
          }
        ]
      }
    ],
    "identifier": 49849884
  },
  {
    "context": [
      "devHubSfdxAuthUrl=$(sfdx force:org:display --verbose -u $DEV_HUB_USERNAME --json | **jq** -r .result.sfdxAuthUrl)",
      "Alternatively, you can use the ConvertFrom-Json command to convert any JSON text into a PowerShell object."
    ],
    "utterance": "Extract the value of result.sfdxAuthUrl from the command output.",
    "expressions": [
      ".result.sfdxAuthUrl"
    ],
    "identifier": 49853966
  },
  {
    "context": [
      "I originally attempted:\r\n\r\n\r\n    [.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, 90line: .90line, 95line: .95line, 99line: .99line, minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds}]\r\n\r\n\r\nand got \r\n\r\n\r\n    jq: error: syntax error, unexpected LITERAL (Unix shell quoting issues?) at <top-level>, line 1:\r\n    [.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, 90line: .90line, 95line: .95line, 99line: .99line, minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds}]                                                                                           \r\n    jq: 1 compile error\r\n    exit status 3",
      "You need to quote the key names of keys that begin with a numeral, e.g.\r\n\r\n    \"90line\": .[\"90line\"]",
      "With your input:\r\n\r\n    $ jq '[.result[] | {labelName, \"90line\": .[\"90line\"] } ]' input.json\r\n    [\r\n      {\r\n        \"labelName\": \"ALL\",\r\n        \"90line\": 8\r\n      },\r\n      {\r\n        \"labelName\": \"100b 3600s Cache\",\r\n        \"90line\": 7\r\n      },\r\n      {\r\n        \"labelName\": \"100b NonCache\",\r\n        \"90line\": 7\r\n      }\r\n    ]"
    ],
    "utterance": "Extract an array of objects containing the labelName and the value of the 90line field for each entry in the result array, including fields that start with a number.",
    "expressions": [
      "[.result[] | {labelName, \"90line\": .[\"90line\"]}]"
    ],
    "data": [
      {
        "input": {
          "api_version": 4,
          "error": null,
          "result": [
            {
              "labelId": "ALL",
              "labelName": "ALL",
              "samples": 30104,
              "avgResponseTime": 6.849,
              "90line": 8,
              "95line": 9,
              "99line": 36,
              "minResponseTime": 2,
              "maxResponseTime": 1951,
              "avgLatency": 5.287,
              "geoMeanResponseTime": 5.484,
              "stDev": 23.765,
              "duration": 302,
              "avgBytes": 110.224,
              "avgThroughput": 99.682,
              "medianResponseTime": 5,
              "errorsCount": 0,
              "errorsRate": 0,
              "hasLabelPassedThresholds": null
            },
            {
              "labelId": "3687c89fac2385d28d53b356d4785418",
              "labelName": "100b 3600s Cache",
              "samples": 7300,
              "avgResponseTime": 6.028,
              "90line": 7,
              "95line": 8,
              "99line": 11,
              "minResponseTime": 2,
              "maxResponseTime": 680,
              "avgLatency": 6.021,
              "geoMeanResponseTime": 5.203,
              "stDev": 16.233,
              "duration": 300,
              "avgBytes": 16.581,
              "avgThroughput": 24.333,
              "medianResponseTime": 5,
              "errorsCount": 0,
              "errorsRate": 0,
              "hasLabelPassedThresholds": null
            },
            {
              "labelId": "f88f8ff81bf9b521134637639a0277be",
              "labelName": "100b NonCache",
              "samples": 729,
              "avgResponseTime": 6.143,
              "90line": 7,
              "95line": 7,
              "99line": 9,
              "minResponseTime": 3,
              "maxResponseTime": 877,
              "avgLatency": 6.136,
              "geoMeanResponseTime": 4.627,
              "stDev": 32.817,
              "duration": 295,
              "avgBytes": 1.64,
              "avgThroughput": 2.471,
              "medianResponseTime": 4,
              "errorsCount": 0,
              "errorsRate": 0,
              "hasLabelPassedThresholds": null
            }
          ]
        },
        "output": [
          {
            "labelName": "ALL",
            "90line": 8
          },
          {
            "labelName": "100b 3600s Cache",
            "90line": 7
          },
          {
            "labelName": "100b NonCache",
            "90line": 7
          }
        ]
      }
    ],
    "identifier": 49647599
  },
  {
    "context": [
      "I store the JSON Information from there into a file before i use JQ 1.5 (under Windows 10) to transform the json into a format that i can upload into a database. But since i use jq in the same powershell enviroment, i think i can avoid that redirection and work directly with the json text (with a variable or with the json text direct in the jq command).",
      "$variable | C:\\jq.exe [Filter]",
      "There was no Explanation in the JQ Manual how to pass json text directly on the commandshell to jq. But i found it."
    ],
    "utterance": "Process JSON text held in a PowerShell variable by piping it directly into jq.",
    "expressions": [
      "$variable | C:\\jq.exe <filter>"
    ],
    "identifier": 49894470
  },
  {
    "context": [
      "I need to modify the query so that is does not return all snapshots, but rather only ones where the name start with 'autosnap'.",
      "Here is a redacted sample output from `aws lightsail get-instance-snapshots`",
      ".instanceSnapshots | map(select(.name|startswith(\"autosnap\")))",
      ".instanceSnapshots\n| map(select(.name|startswith(\"autosnap\")))\n| map(select(.fromInstanceName == \"WordPress-Test-Instance\"))\n| sort_by(.createdAt)\n| .[].name"
    ],
    "utterance": "Get names of instance snapshots where 'fromInstanceName' is 'WordPress-Test-Instance' and the name starts with 'autosnap', sorted by creation time.",
    "expressions": [
      ".instanceSnapshots | map(select(.name|startswith(\"autosnap\") and .fromInstanceName == \"WordPress-Test-Instance\")) | sort_by(.createdAt) | .[].name"
    ],
    "data": [
      {
        "input": {
          "instanceSnapshots": [
            {
              "location": {
                "availabilityZone": "all",
                "regionName": "*****"
              },
              "arn": "*****",
              "fromBlueprintId": "wordpress_4_9_2_1",
              "name": "autosnap-WordPress-Test-Instance-2018-04-16_01.46",
              "fromInstanceName": "WordPress-Test-Instance",
              "fromBundleId": "nano_1_2",
              "supportCode": "*****",
              "sizeInGb": 20,
              "createdAt": 1523843190.117,
              "fromAttachedDisks": [],
              "fromInstanceArn": "*****",
              "resourceType": "InstanceSnapshot",
              "state": "available"
            },
            {
              "location": {
                "availabilityZone": "all",
                "regionName": "*****"
              },
              "arn": "*****",
              "fromBlueprintId": "wordpress_4_9_2_1",
              "name": "Premanent-WordPress-Test-Instance-2018-04-16_01.40",
              "fromInstanceName": "WordPress-Test-Instance",
              "fromBundleId": "nano_1_2",
              "supportCode": "*****",
              "sizeInGb": 20,
              "createdAt": 1523842851.69,
              "fromAttachedDisks": [],
              "fromInstanceArn": "*****",
              "resourceType": "InstanceSnapshot",
              "state": "available"
            }
          ]
        },
        "output": [
          "autosnap-WordPress-Test-Instance-2018-04-16_01.46"
        ]
      }
    ],
    "identifier": 49850316
  },
  {
    "context": [
      "I would like to grab value of `jira-key`",
      "if i'm using `.jira-key[]` its not working",
      "you can use this",
      "jq '.properties[\"jira-key\"]' test.json",
      "otherwise jq parses dash as a subtraction"
    ],
    "utterance": "Access the value of the 'jira-key' key inside the 'properties' object, where the key includes a dash.",
    "expressions": [
      ".properties[\"jira-key\"]"
    ],
    "data": [
      {
        "input": {
          "id": "8a9o0laf3ff0",
          "displayId": "8a0a",
          "author": {
            "name": "Rahul",
            "emailAddress": "donotreply@mail.com"
          },
          "authorTimestamp": 1524168139000,
          "message": "SD-90",
          "parents": [
            {
              "id": "8c1679f0813c",
              "displayId": "8c0f",
              "author": {
                "name": "Sahotay",
                "emailAddress": "donotreply@mail.com"
              },
              "authorTimestamp": 1523544887000,
              "message": "Fixing issues in SD-88",
              "parents": [
                {
                  "id": "d022838cf4e6",
                  "displayId": "d0a3"
                }
              ]
            }
          ],
          "properties": {
            "jira-key": [
              "SD-90"
            ]
          }
        },
        "output": [
          "SD-90"
        ]
      }
    ],
    "identifier": 49930733
  },
  {
    "context": [
      "I'm trying to extract a series of properties (named in an input file) in jq and getting error when I feed those from bash via a loop:",
      "cat >big.json <<EOF\n{\n  \"cfg\": {\n    \"keyload\": {\n      \"backend\": {\n    \"app\": {\n      \"shutdown\": {\n        \"timeout\": \"5s\"\n                  },\n      \"jmx\": {\n        \"enable\": true\n                    }\n           }\n       }\n     }\n}\n}\nEOF",
      "cat >big.properties.service <<EOF\ncfg.keyload.backend.app.shutdown.timeout\ncfg.keyload.backend.app.jmx.enable\ncfg.keyload.backend.app.jmx.nonexistent\ncfg.nonexistent\nEOF",
      "...output should be:\n\n    cfg.keyload.backend.app.shutdown.timeout\n    \"5s\"\n    cfg.keyload.backend.app.jmx.enable\n    true\n    cfg.keyload.backend.app.jmx.nonexistent\n    null\n    cfg.nonexistent\n    null",
      "jq -rR --argfile infile big.json '\nsub(\"\\r$\"; \"\") as $keyname\n| ($keyname | split(\".\")) as $pieces\n| (reduce $pieces[] as $piece ($infile; .[$piece]?)) as $value\n| ($keyname, ($value | tojson))\n' <big.properties.service",
      "jq --argfile big big.json '\n    ., (split(\".\") as $p | $big | getpath($p) | tojson)\n' -Rr big.properties.service"
    ],
    "utterance": "For each line in a file containing dot-separated property paths, output the path and the corresponding value from a data file (outputting null if not found), in order.",
    "expressions": [
      "jq -rR --argfile infile big.json '\nsub(\"\\r$\"; \"\") as $keyname\n| ($keyname | split(\".\")) as $pieces\n| (reduce $pieces[] as $piece ($infile; .[$piece]?)) as $value\n| ($keyname, ($value | tojson))\n' <big.properties.service",
      "jq --argfile big big.json '\n    ., (split(\".\") as $p | $big | getpath($p) | tojson)\n' -Rr big.properties.service"
    ],
    "data": [
      {
        "input": {
          "json": {
            "cfg": {
              "keyload": {
                "backend": {
                  "app": {
                    "shutdown": {
                      "timeout": "5s"
                    },
                    "jmx": {
                      "enable": true
                    }
                  }
                }
              }
            }
          },
          "properties": [
            "cfg.keyload.backend.app.shutdown.timeout",
            "cfg.keyload.backend.app.jmx.enable",
            "cfg.keyload.backend.app.jmx.nonexistent",
            "cfg.nonexistent"
          ]
        },
        "output": [
          "cfg.keyload.backend.app.shutdown.timeout",
          "\"5s\"",
          "cfg.keyload.backend.app.jmx.enable",
          "true",
          "cfg.keyload.backend.app.jmx.nonexistent",
          "null",
          "cfg.nonexistent",
          "null"
        ]
      }
    ],
    "identifier": 49920852
  },
  {
    "context": [
      "I would like to filter in two ways:\r\n\r\n- select only the first-level objects that have at least one ```role_name``` (inside the ```roles``` array) whose value is HOUSE; \r\n- and from this group select only the ones that have at least one ```start``` whose date is in 2017 or after.\r\n\r\nIn the json above \"Corrine Odile\" would be the only one selected.",
      "Requirements of the form \"at least one\" can usually be satisfied efficiently using `any/2`, e.g. \r\n\r\n    any(.roles[]; .role_name == \"HOUSE\")",
      "The check for the year can (apparently) be accomplished by:\r\n\r\n    .start | .[:4] | tonumber >= 2017",
      "To produce an array of objects satisfying the two conditions:\r\n\r\n    map(select(\r\n      any(.roles[]; .role_name == \"HOUSE\") and\r\n      any(.roles[]; .start[:4] | tonumber >= 2017) ))"
    ],
    "utterance": "Select all objects that have at least one role with role_name equal to HOUSE and at least one role with a start date in 2017 or later.",
    "expressions": [
      "map(select(any(.roles[]; .role_name == \"HOUSE\") and any(.roles[]; .start[:4] | tonumber >= 2017)))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Corrine",
            "firstname": "Odile",
            "uid": "PA2685",
            "roles": [
              {
                "role_name": "GQ",
                "start": "2012-06-20"
              },
              {
                "role_name": "HOUSE",
                "start": "2012-06-26"
              },
              {
                "role_name": "HOUSE",
                "start": "2017-06-28"
              }
            ]
          },
          {
            "name": "Blanche",
            "firstname": "Matthieu",
            "uid": "PA2685",
            "roles": [
              {
                "role_name": "SENATE",
                "start": "2014-06-20"
              },
              {
                "role_name": "SENATE",
                "start": "2012-06-26"
              },
              {
                "role_name": "SENATE",
                "start": "2012-06-28"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "Corrine",
            "firstname": "Odile",
            "uid": "PA2685",
            "roles": [
              {
                "role_name": "GQ",
                "start": "2012-06-20"
              },
              {
                "role_name": "HOUSE",
                "start": "2012-06-26"
              },
              {
                "role_name": "HOUSE",
                "start": "2017-06-28"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 49936680
  },
  {
    "context": [
      "There is an json object with n nested objects, where the key ist arbitrary and the nested objects have all the same structure.",
      "with jq the output should  be an array and look like this:",
      "[{\"name\":\"albert\",\"age\":35},{\"name\":\"sarah\",\"age\":32},{\"name\":\"otto\",\"age\":27}]",
      "to_entries | map( {name: .key, age: .value.age} )"
    ],
    "utterance": "Convert an object with arbitrary keys each mapping to an object with an age property into an array of objects with name and age properties, where name is the original key.",
    "expressions": [
      "to_entries | map({name: .key, age: .value.age})"
    ],
    "data": [
      {
        "input": {
          "albert": {
            "age": 35
          },
          "sarah": {
            "age": 33
          },
          "otto": {
            "age": 27
          }
        },
        "output": [
          {
            "name": "albert",
            "age": 35
          },
          {
            "name": "sarah",
            "age": 33
          },
          {
            "name": "otto",
            "age": 27
          }
        ]
      }
    ],
    "identifier": 49960144
  },
  {
    "context": [
      "Now I want to get a text like this (all values of this json):\n\n    \"error\", \"No files were uploaded.\"",
      "The output can be formatted as csv by using the `--raw-output` option:\n\n    jq --raw-output '\"\\\"\\(.code)\\\"\", \\\"\\(.msg)\\\"\"'",
      "You might like to consider a generic solution:\n\n    jq -r '[.[]] | @csv'"
    ],
    "utterance": "Output all top-level values joined and formatted as a CSV text row, e.g., \"error\", \"No files were uploaded.\" for the given object.",
    "expressions": [
      "jq --raw-output '[.[]] | @csv'",
      "jq --raw-output '\"\\\"\\(.code)\\\"\", \\\"\\(.msg)\\\"\"'"
    ],
    "data": [
      {
        "input": {
          "code": "error",
          "msg": "No files were uploaded."
        },
        "output": "\"error\",\"No files were uploaded.\"\n"
      }
    ],
    "identifier": 49967054
  },
  {
    "context": [
      "Is there a way to have `jq` substitute the characters `\\n` for an actual newline in command output?",
      "I'd love if I could pipe it through `jq` and see the value of the field formatted with actual newlines, like ...",
      "Is there a way to do this?"
    ],
    "utterance": "Replace literal '\\n' in the value of the 'stderr' field with actual newline characters in output.",
    "expressions": [
      ".stderr | gsub(\"\\\\n\"; \"\\n\")"
    ],
    "data": [
      {
        "input": {
          "stderr": "Traceback (most recent call last):\\n  File \\\"download.py\\\", line 157, in <module>\\n    cli()\\n  File \\\"/var/task/click/core.py\\\", line 722, in __call__\\n    return self.main(*args, **kwargs)\\n  File \\\"/var/task/click/core.py\\\", line 697, in main\\n    rv = self.invoke(ctx)\\n  File \\\"/var/task/click/core.py\\\", line 895, in invoke\\n    return ctx.invoke(self.callback, **ctx.params)\\n  File \\\"/var/task/click/core.py\\\", line 535, in invoke\\n    return callback(*args, **kwargs)\\n  File \\\"download.py\\\", line 77, in cli\\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\\n  File \\\"/var/lang/lib/python3.6/multiprocessing/pool.py\\\", line 260, in map\\n    return self._map_async(func, iterable, mapstar, chunksize).get()\\n  File \\\"/var/lang/lib/python3.6/multiprocessing/pool.py\\\", line 608, in get\\n    raise self._value\\n  File \\\"/var/lang/lib/python3.6/multiprocessing/pool.py\\\", line 119, in worker\\n    result = (True, func(*args, **kwds))\\n  File \\\"/var/lang/lib/python3.6/multiprocessing/pool.py\\\", line 44, in mapstar\\n    return list(map(*args))\\n  File \\\"download.py\\\", line 77, in <lambda>\\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\\n  File \\\"/var/task/src/keepout.py\\\", line 63, in download\\n    self.tempfile = mgr.download_url(self.url_or_path, suffix=file_extension)\\n  File \\\"/var/task/src/download.py\\\", line 24, in download_url\\n    shutil.copyfileobj(fsrc, fdst, length=16 * 1024)\\n  File \\\"/var/lang/lib/python3.6/shutil.py\\\", line 82, in copyfileobj\\n    fdst.write(buf)\\n  File \\\"/var/lang/lib/python3.6/tempfile.py\\\", line 483, in func_wrapper\\n    return func(*args, **kwargs)\\nOSError: [Errno 28] No space left on device\\n"
        },
        "output": "Traceback (most recent call last):\n  File \"download.py\", line 157, in <module>\n    cli()\n  File \"/var/task/click/core.py\", line 722, in __call__\n    return self.main(*args, **kwargs)\n  File \"/var/task/click/core.py\", line 697, in main\n    rv = self.invoke(ctx)\n  File \"/var/task/click/core.py\", line 895, in invoke\n    return ctx.invoke(self.callback, **ctx.params)\n  File \"/var/task/click/core.py\", line 535, in invoke\n    return callback(*args, **kwargs)\n  File \"download.py\", line 77, in cli\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\n  File \"/var/lang/lib/python3.6/multiprocessing/pool.py\", line 260, in map\n    return self._map_async(func, iterable, mapstar, chunksize).get()\n  File \"/var/lang/lib/python3.6/multiprocessing/pool.py\", line 608, in get\n    raise self._value\n  File \"/var/lang/lib/python3.6/multiprocessing/pool.py\", line 119, in worker\n    result = (True, func(*args, **kwds))\n  File \"/var/lang/lib/python3.6/multiprocessing/pool.py\", line 44, in mapstar\n    return list(map(*args))\n  File \"download.py\", line 77, in <lambda>\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\n  File \"/var/task/src/keepout.py\", line 63, in download\n    self.tempfile = mgr.download_url(self.url_or_path, suffix=file_extension)\n  File \"/var/task/src/download.py\", line 24, in download_url\n    shutil.copyfileobj(fsrc, fdst, length=16 * 1024)\n  File \"/var/lang/lib/python3.6/shutil.py\", line 82, in copyfileobj\n    fdst.write(buf)\n  File \"/var/lang/lib/python3.6/tempfile.py\", line 483, in func_wrapper\n    return func(*args, **kwargs)\nOSError: [Errno 28] No space left on device\n"
      }
    ],
    "identifier": 49930626
  },
  {
    "context": [
      "I\u2019m trying to filter out the field \"name\" to store in a file.",
      "print(jq(\".[name]\").transform(json.loads(r)))",
      "You have probably used `import jq` instead of `from jq import jq`."
    ],
    "utterance": "Extract the value of the 'name' field from the API response.",
    "expressions": [
      ".name"
    ],
    "identifier": 49976488
  },
  {
    "context": [
      "How can I get the output as\nnodered-test STARTED 2018-04-10T17:32:06Z\nNodeRedTestApp STARTED 2018-04-09T21:23:27Z\n\nSo that I can assign it to a bash script array.",
      "jq -r '.apps[] | [.routes[].host, .state, .package_updated_at] | join(\" \")' test.json\nThe output:\n    nodered-test STARTED 2018-04-10T17:32:06Z\n    NodeRedTestApp STARTED 2018-04-09T21:23:27Z\n"
    ],
    "utterance": "Produce one line per app with its route host, state, and package_updated_at fields separated by spaces.",
    "expressions": [
      ".apps[] | [.routes[].host, .state, .package_updated_at] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "guid": "dce38b4b-9989-42d2-b6bd-702645e344cf",
          "name": "dev",
          "apps": [
            {
              "guid": "5d5498cb-a885-4242-a55a-d7d286a1cf48",
              "urls": [
                "nodered.cloudfoundry.org"
              ],
              "routes": [
                {
                  "guid": "aca4d04b-f99d-4b43-afaa-82ab41afa07c",
                  "host": "nodered-test",
                  "port": null,
                  "path": "",
                  "domain": {
                    "guid": "f4b90d7e-2cd3-4d30-b200-f28bbaf6be20",
                    "name": "cloudfoundry.org"
                  }
                }
              ],
              "service_count": 1,
              "service_names": [
                "nodered-test-cloudantNoSQLDB"
              ],
              "running_instances": 1,
              "name": "perik-nodered-test",
              "production": false,
              "space_guid": "dce38b4b-9989-42d2-b6bd-702645e344cf",
              "stack_guid": "ac91d31a-86a3-453b-babf-8d49c9d763fc",
              "buildpack": null,
              "detected_buildpack": "SDK for Node.js(TM) (ibm-node.js-6.13.0, buildpack-v3.20-20180403-1426)",
              "detected_buildpack_guid": "33e9e82f-8846-4362-a60a-92964285a31e",
              "environment_json": {},
              "memory": 256,
              "instances": 1,
              "disk_quota": 1024,
              "state": "STARTED",
              "version": "8c8c97a0-bc2e-424c-a0a3-d64704feb634",
              "command": null,
              "console": false,
              "debug": null,
              "staging_task_id": "539f460c-e4d2-49f9-b5e5-9f4fd31a8370",
              "package_state": "STAGED",
              "health_check_type": "port",
              "health_check_timeout": null,
              "health_check_http_endpoint": null,
              "staging_failed_reason": null,
              "staging_failed_description": null,
              "diego": true,
              "docker_image": null,
              "package_updated_at": "2018-04-10T17:32:06Z",
              "detected_start_command": "./vendor/initial_startup.rb",
              "enable_ssh": true,
              "ports": null
            },
            {
              "guid": "4089ce19-19fb-467b-8876-3635819d5d91",
              "urls": [
                "nodered.cloudfoundry.org"
              ],
              "routes": [
                {
                  "guid": "b79988d8-5ac5-455d-8fdd-00bc208dd2bc",
                  "host": "NodeRedTestApp",
                  "port": null,
                  "path": "",
                  "domain": {
                    "guid": "f4b90d7e-2cd3-4d30-b200-f28bbaf6be20",
                    "name": "cloudfoundry.org"
                  }
                }
              ],
              "service_count": 1,
              "service_names": [
                "NodeRedTestApp-cloudantNoSQLDB"
              ],
              "running_instances": 1,
              "name": "perik-NodeRedTestApp",
              "production": false,
              "space_guid": "dce38b4b-9989-42d2-b6bd-702645e344cf",
              "stack_guid": "ac91d31a-86a3-453b-babf-8d49c9d763fc",
              "buildpack": null,
              "detected_buildpack": "SDK for Node.js(TM) (ibm-node.js-6.13.0, buildpack-v3.20-20180403-1426)",
              "detected_buildpack_guid": "33e9e82f-8846-4362-a60a-92964285a31e",
              "environment_json": {},
              "memory": 256,
              "instances": 1,
              "disk_quota": 1024,
              "state": "STARTED",
              "version": "17175bdb-df93-4745-9a17-cf214fe05976",
              "command": null,
              "console": false,
              "debug": null,
              "staging_task_id": "5c74633a-25db-4adf-9eb8-09454a70be52",
              "package_state": "STAGED",
              "health_check_type": "port",
              "health_check_timeout": null,
              "health_check_http_endpoint": null,
              "staging_failed_reason": null,
              "staging_failed_description": null,
              "diego": true,
              "docker_image": null,
              "package_updated_at": "2018-04-09T21:23:27Z",
              "detected_start_command": "./vendor/initial_startup.rb",
              "enable_ssh": true,
              "ports": null
            }
          ]
        },
        "output": [
          "nodered-test STARTED 2018-04-10T17:32:06Z",
          "NodeRedTestApp STARTED 2018-04-09T21:23:27Z"
        ]
      }
    ],
    "identifier": 49779617
  },
  {
    "context": [
      "I have a response from curl in a format like this:\r\n\r\n    [\r\n      {\r\n        \"list\": [\r\n          {\r\n            \"value\": 1,\r\n            \"id\": 12\r\n          },\r\n          {\r\n            \"value\": 15,\r\n            \"id\": 13\r\n          },\r\n          {\r\n            \"value\": -4,\r\n            \"id\": 14\r\n          }\r\n        ]\r\n      },\r\n      ...\r\n    ]",
      "Given a mapping between ids like this:\r\n\r\n    {\r\n      \"12\": \"newId1\",\r\n      \"13\": \"newId2\",\r\n      \"14\": \"newId3\"\r\n    }",
      "I want to make this:\r\n\r\n    [\r\n      {\r\n        \"list\": {\r\n          \"newId1\": 1,\r\n          \"newId2\": 15,\r\n          \"newId3\": -4,\r\n        }\r\n      },\r\n      ...\r\n    ]",
      "I'd do it like this:\r\n\r\n    .[].list |= reduce .[] as $i ({};\r\n        ($i.id|tostring) as $k\r\n          | (select($mapping | has($k))[$mapping[$k]] = $i.value) // .\r\n    )",
      "Here is a reduce-free solution to the revised problem. \r\n\r\n    map( .list\r\n         |= (map( mapping[.id|tostring] as $mapped\r\n                  | select($mapped)\r\n                  |  {($mapped): .value} )\r\n             | add) )"
    ],
    "utterance": "For each object, replace the 'list' array with an object where each key is looked up from the mapping using the item's id, and the value is the item's value.",
    "expressions": [
      ".[].list |= reduce .[] as $i ({};\n    ($i.id|tostring) as $k\n      | (select($mapping | has($k))[$mapping[$k]] = $i.value) // .\n)",
      "map( .list |= (map( mapping[.id|tostring] as $mapped | select($mapped) | {($mapped): .value} ) | add) )"
    ],
    "data": [
      {
        "input": [
          {
            "list": [
              {
                "value": 1,
                "id": 12
              },
              {
                "value": 15,
                "id": 13
              },
              {
                "value": -4,
                "id": 14
              }
            ]
          }
        ],
        "output": [
          {
            "list": {
              "newId1": 1,
              "newId2": 15,
              "newId3": -4
            }
          }
        ]
      }
    ],
    "identifier": 49958035
  },
  {
    "context": [
      "mp_keys=\"a,b,c,d\"",
      "echo '{\"a\":1, \"b\":2, \"c\":3, \"d\": 4}' | jq -r --arg mpk \"$mp_keys\" '($mpk|split(\",\")) as $mpkeys | [ .[ $mpkeys[] ] ] | @csv '",
      "would yield:\n\n    1,2,3,4"
    ],
    "utterance": "Produce a CSV row containing the values of the object properties whose keys are listed in a variable, with the order matching the variable.",
    "expressions": [
      "($mpk|split(\",\")) as $mpkeys | [ .[ $mpkeys[] ] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3,
          "d": 4
        },
        "output": "1,2,3,4"
      }
    ],
    "identifier": 49972375
  },
  {
    "context": [
      "I would like to do something like the following:",
      "cat /tmp/stuff2 | jq '.x | <1st level|not child>'",
      "{",
      "  \"a\",",
      "  \"b\",",
      "  \"c\",",
      "  \"d\"",
      "}",
      "I guess you want [`keys`][1]:",
      "jq '.x|keys' input.json",
      "[",
      "  \"a\",",
      "  \"b\",",
      "  \"c\",",
      "  \"d\"",
      "]"
    ],
    "utterance": "Get the top-level keys under the object at key x.",
    "expressions": [
      ".x | keys"
    ],
    "data": [
      {
        "input": {
          "x": {
            "a": {
              "c1": 2,
              "c2": "sss"
            },
            "b": {
              "c1": 3,
              "c2": "sfs",
              "c3": {
                "d1": "aa",
                "d2": 3
              }
            },
            "c": {
              "c1": 5,
              "c2": "ssy"
            },
            "d": {
              "c1": 8,
              "c2": "esy"
            }
          }
        },
        "output": [
          "a",
          "b",
          "c",
          "d"
        ]
      }
    ],
    "identifier": 50031040
  },
  {
    "context": [
      "Now, I want to do opposite above. genre value in the JSON is my regex and what I pass in test is my data. For example:",
      "map(select(\"progressive\" | test(.[\"genre\"])))",
      "**EXPECTED RESULT**:\n\n    [\n      {\n        \"genre\": \"^progressive$\"\n      }\n    ]",
      "The following seems to be what you're after:\n\n    map(. as $in | select(\"progressive\" | test($in|.[\"genre\"])))",
      "A little less typing ...\n\n    map(.genre as $g | select(\"progressive\" | test($g)))"
    ],
    "utterance": "Select all objects where the 'genre' value, used as a regex, matches the string 'progressive'.",
    "expressions": [
      "map(. as $in | select(\"progressive\" | test($in|.[\"genre\"])))",
      "map(.genre as $g | select(\"progressive\" | test($g)))"
    ],
    "data": [
      {
        "input": [
          {
            "genre": "^progressive$"
          },
          {
            "genre": "^abc$"
          }
        ],
        "output": [
          {
            "genre": "^progressive$"
          }
        ]
      }
    ],
    "identifier": 50032199
  },
  {
    "context": [
      "I want to split that into multiple files of 10000 top level objects each (retaining the structure inside each).",
      "jq -n --stream 'fromstream(1|truncate_stream(inputs))' |",
      "jq -c '.[]' INPUTFILE",
      "The sliced output files can contain:\n - an array of Json inputs with size=$sliceSize",
      "write_files() {\n  ...\n  jq '.'      > $FILE_NAME <<< \"$line\"   # array of formatted json inputs",
      "jq -n -c --argjson sliceSize $SLICE_SIZE \"$JQ_SLICE_INPUTS\" |",
      "As input is possible:\n - an array of Json inputs"
    ],
    "utterance": "Split a large file containing an array of objects into multiple files, each containing 10000 objects, preserving the nested structure of each object.",
    "expressions": [
      "jq -c '.[]' INPUTFILE",
      "jq -n --stream 'fromstream(1|truncate_stream(inputs))'",
      "jq -n -c --argjson sliceSize 10000 \"$JQ_SLICE_INPUTS\""
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "user": {
              "name": "Nichols Cockle",
              "email": "ncockle0@tmall.com",
              "address": {
                "city": "Turt",
                "state": "Th\u1ecb Tr\u1ea5n Y\u00ean Ph\u00fa"
              }
            },
            "product": {
              "name": "Lychee - Canned",
              "code": "36987-1526"
            }
          },
          {
            "id": 2,
            "user": {
              "name": "Isacco Scrancher",
              "email": "iscrancher1@aol.com",
              "address": {
                "city": "Likwatang Timur",
                "state": "Biharamulo"
              }
            },
            "product": {
              "name": "Beer - Original Organic Lager",
              "code": "47993-200"
            }
          },
          {
            "id": 3,
            "user": {
              "name": "Elga Sikora",
              "email": "esikora2@statcounter.com",
              "address": {
                "city": "Wenheng",
                "state": "Piedra del \u00c1guila"
              }
            },
            "product": {
              "name": "Parsley - Dried",
              "code": "36987-1632"
            }
          },
          {
            "id": 4,
            "user": {
              "name": "Andria Keatch",
              "email": "akeatch3@salon.com",
              "address": {
                "city": "Arras",
                "state": "Iracem\u00e1polis"
              }
            },
            "product": {
              "name": "Wine - Segura Viudas Aria Brut",
              "code": "51079-385"
            }
          },
          {
            "id": 5,
            "user": {
              "name": "Dara Sprowle",
              "email": "dsprowle4@slate.com",
              "address": {
                "city": "Huatai",
                "state": "Kaduna"
              }
            },
            "product": {
              "name": "Pork - Hock And Feet Attached",
              "code": "0054-8648"
            }
          }
        ],
        "output": [
          [
            {
              "id": 1,
              "user": {
                "name": "Nichols Cockle",
                "email": "ncockle0@tmall.com",
                "address": {
                  "city": "Turt",
                  "state": "Th\u1ecb Tr\u1ea5n Y\u00ean Ph\u00fa"
                }
              },
              "product": {
                "name": "Lychee - Canned",
                "code": "36987-1526"
              }
            },
            {
              "id": 2,
              "user": {
                "name": "Isacco Scrancher",
                "email": "iscrancher1@aol.com",
                "address": {
                  "city": "Likwatang Timur",
                  "state": "Biharamulo"
                }
              },
              "product": {
                "name": "Beer - Original Organic Lager",
                "code": "47993-200"
              }
            }
          ],
          [
            {
              "id": 3,
              "user": {
                "name": "Elga Sikora",
                "email": "esikora2@statcounter.com",
                "address": {
                  "city": "Wenheng",
                  "state": "Piedra del \u00c1guila"
                }
              },
              "product": {
                "name": "Parsley - Dried",
                "code": "36987-1632"
              }
            },
            {
              "id": 4,
              "user": {
                "name": "Andria Keatch",
                "email": "akeatch3@salon.com",
                "address": {
                  "city": "Arras",
                  "state": "Iracem\u00e1polis"
                }
              },
              "product": {
                "name": "Wine - Segura Viudas Aria Brut",
                "code": "51079-385"
              }
            }
          ],
          [
            {
              "id": 5,
              "user": {
                "name": "Dara Sprowle",
                "email": "dsprowle4@slate.com",
                "address": {
                  "city": "Huatai",
                  "state": "Kaduna"
                }
              },
              "product": {
                "name": "Pork - Hock And Feet Attached",
                "code": "0054-8648"
              }
            }
          ]
        ]
      }
    ],
    "identifier": 49808581
  },
  {
    "context": [
      "My expected result:\r\n\r\n    [\r\n      {\r\n        \"Data\": \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010070\\\"}}\"\r\n       },\r\n      {\r\n        \"Data\": \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010100\\\"}}\"\r\n      }\r\n    ]",
      "So far I am only able to add quotes by:\r\n\r\n    .features[] | del(.type) | tojson\r\n\r\nwhich will only give me:\r\n\r\n    \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010070\\\"}}\"\r\n    \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010100\\\"}}\"",
      "jq '.features | map(del(.type) | {Data: tojson})' file.json",
      "jq '[.features[] | del(.type) | {Data: tojson}]' file.json",
      "The output:\r\n\r\n    [\r\n      {\r\n        \"Data\": \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010070\\\"}}\"\r\n      },\r\n      {\r\n        \"Data\": \"{\\\"properties\\\":{\\\"district\\\":\\\"d1\\\",\\\"district_code\\\":\\\"101\\\",\\\"block_code\\\":\\\"1010100\\\"}}\"\r\n      }\r\n    ]"
    ],
    "utterance": "Wrap each element of the features array without its type key as a JSON string under the Data key in a new array.",
    "expressions": [
      ".features | map(del(.type) | {Data: tojson})",
      "[.features[] | del(.type) | {Data: tojson}]"
    ],
    "data": [
      {
        "input": {
          "type": "type1",
          "name": "abc",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "district": "d1",
                "district_code": "101",
                "block_code": "1010070"
              }
            },
            {
              "type": "Feature",
              "properties": {
                "district": "d1",
                "district_code": "101",
                "block_code": "1010100"
              }
            }
          ]
        },
        "output": [
          {
            "Data": "{\"properties\":{\"district\":\"d1\",\"district_code\":\"101\",\"block_code\":\"1010070\"}}"
          },
          {
            "Data": "{\"properties\":{\"district\":\"d1\",\"district_code\":\"101\",\"block_code\":\"1010100\"}}"
          }
        ]
      }
    ],
    "identifier": 50023609
  },
  {
    "context": [
      "Here is my input:\r\n\r\n    {\r\n    ...\r\n      },\r\n      \"Johnny Cage\": {\r\n        \"firstname\": \"Johnny\",\r\n        \"lastname\": \"Cage\",\r\n        \"height\": 183,\r\n        \"weight\": 82,\r\n        \"hands\": 2,\r\n        \"legs\": 2,\r\n        ...\r\n      },\r\n      ...\r\n    }",
      "Desired output:\r\n\r\n    mk.fighter.Johnny.Cage.firstname Johnny\r\n    mk.fighter.Johnny.Cage.lastname Cage\r\n    mk.fighter.Johnny.Cage.height 183\r\n    mk.fighter.Johnny.Cage.weight 82\r\n    mk.fighter.Johnny.Cage.hands 2\r\n    mk.fighter.Johnny.Cage.legs 2\r\n    ...",
      "jq -r 'to_entries[] | (.key | sub(\" \"; \".\")) as $name \n       | .value | to_entries[]\n       | \"mk.fighter.\\($name).\\(.key) \\(.value)\"' input.json",
      "To get $name as a combination of inner firstname and lastname keys replace (.key | sub(\" \"; \".\")) as $name with \"\\(.value.firstname).\\(.value.lastname)\" as $name"
    ],
    "utterance": "List all top-level objects' properties as key-value lines, prefixing each with mk.fighter, and using their firstname and lastname fields joined by a dot as the identifier in the key.",
    "expressions": [
      "to_entries[] | \"\\(.value.firstname).\\(.value.lastname)\" as $name | .value | to_entries[] | \"mk.fighter.\\($name).\\(.key) \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "Johnny Cage": {
            "firstname": "Johnny",
            "lastname": "Cage",
            "height": 183,
            "weight": 82,
            "hands": 2,
            "legs": 2
          }
        },
        "output": [
          "mk.fighter.Johnny.Cage.firstname Johnny",
          "mk.fighter.Johnny.Cage.lastname Cage",
          "mk.fighter.Johnny.Cage.height 183",
          "mk.fighter.Johnny.Cage.weight 82",
          "mk.fighter.Johnny.Cage.hands 2",
          "mk.fighter.Johnny.Cage.legs 2"
        ]
      }
    ],
    "identifier": 50029781
  },
  {
    "context": [
      "whenever it finds a msg in log.json that matches a msg in messages.json, print the value of out in the corresponding line in messages.json.",
      "jq --argfile a log.json --argfile b messages.json -n 'if ($a[].msg == $b[].msg) then $b[].out else empty end'",
      "INDEX($messages[]; .msg) as $dict\n| inputs\n| $dict[.msg]\n| .out ",
      "jq -n --slurpfile messages messages.json -f program.jq log.json",
      "The above will print `null` if the `.msg` in the log file is not in the dictionary. To filter out these nulls, you could (for example) add `select(.)` to the pipeline."
    ],
    "utterance": "Print the value of 'out' from messages.json for each entry in log.json where 'msg' matches.",
    "expressions": [
      "INDEX($messages[]; .msg) as $dict | inputs | $dict[.msg] | .out",
      "INDEX($messages[]; .msg) as $dict | inputs | $dict[.msg] | .out | select(.)"
    ],
    "data": [
      {
        "input": [
          {
            "msg": "Service starting up!"
          },
          {
            "msg": "Running a job!"
          },
          {
            "msg": "Error detected!"
          }
        ],
        "output": [
          "The service has started",
          "Uh oh, there was an error!"
        ]
      }
    ],
    "identifier": 50066818
  },
  {
    "context": [
      "But I am stuck on updating the key value pairs in an array (env). I have it working when I hard code the array index. But this makes it brittle. Is there a correct way to look up the environment name and update it's value with a prefix.",
      "if .kind == \"Deployment\" \nthen (.metadata.name,.spec.template.metadata.labels.app) |= \"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\") | \n    if .spec.template.spec.containers[].env[].name == \"MYROLE\" then \n        .spec.template.spec.containers[].env[0].value  = \"ORG-\" + \"DEV-\" + .spec.template.spec.containers[].env[0].value \n    else empty end ",
      "Your query can then be recast as follows:\n\n    if .kind == \"Deployment\" \n    then (.metadata.name,.spec.template.metadata.labels.app) |=\n             \"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\")\n          | (.spec.template.spec.containers[].env | indexof(.name == \"MYROLE\")) as $ix\n          | if $ix \n            then .spec.template.spec.containers[].env[$ix].value |= \"ORG-\" + \"DEV-\" + .\n            else empty\n            end ",
      "The following assumes that all \"MYROLE\" components are to be modified:\n\n    if .kind == \"Deployment\" \n    then (.metadata.name,.spec.template.metadata.labels.app) |=\n            (\"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\"))\n          | .spec.template.spec as $spec\n          | reduce range(0; $spec.containers | length) as $c (.;\n\t      reduce range(0; $spec.containers[$c].env|length) as $ix (.;\n\t        if $spec.containers[$c].env[$ix].name == \"MYROLE\"\n\t        then .spec.template.spec.containers[$c].env[$ix].value |=\n\t          \"ORG-\" + \"DEV-\" + .\n            else .\n            end))",
      "we'll focus on the goal of updating \n`.containers[$i].env[$j].value` \nif `.containers[$i].env[$j].name` is a specified value, no matter where this relative path occurs.",
      "def relevantPaths($value):\n  . as $in\n  | paths \n  | select(.[-1] == \"name\" and .[-3] == \"env\" and .[-5] == \"containers\") as $p\n  | select($in|getpath($p) == $value) ;\n  \nreduce (relevantPaths(\"MYROLE\") | ((.[-1] = \"value\"))) as $p (.;\n  setpath($p; \"ORG-DEV-\" + getpath($p)) )"
    ],
    "utterance": "Update every value field in any env array where name is MYROLE to have the prefix ORG-DEV-.",
    "expressions": [
      "if .kind == \"Deployment\" \nthen (.metadata.name,.spec.template.metadata.labels.app) |=\n         \"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\")\n      | (.spec.template.spec.containers[].env | indexof(.name == \"MYROLE\")) as $ix\n      | if $ix \n        then .spec.template.spec.containers[].env[$ix].value |= \"ORG-\" + \"DEV-\" + .\n        else empty\n        end \nelif .kind == \"Service\"\nthen (.metadata.name,.metadata.labels.name,.spec.selector.app) |=\n  \"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\") \nelse .\nend",
      "if .kind == \"Deployment\" \nthen (.metadata.name,.spec.template.metadata.labels.app) |=\n        (\"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\"))\n      | .spec.template.spec as $spec\n      | reduce range(0; $spec.containers | length) as $c (.;\n\t  reduce range(0; $spec.containers[$c].env|length) as $ix (.;\n\t    if $spec.containers[$c].env[$ix].name == \"MYROLE\"\n\t    then .spec.template.spec.containers[$c].env[$ix].value |=\n\t      \"ORG-\" + \"DEV-\" + .\n        else .\n        end))\nelif .kind == \"Service\" \nthen (.metadata.name,.metadata.labels.name,.spec.selector.app) |=\n       \"ORG-\" + \"DEV-\" +  sub(\"-\\\\$appEnv\";\"\") \nelse .\nend",
      "def relevantPaths($value):\n  . as $in\n  | paths \n  | select(.[-1] == \"name\" and .[-3] == \"env\" and .[-5] == \"containers\") as $p\n  | select($in|getpath($p) == $value) ;\n\nreduce (relevantPaths(\"MYROLE\") | ((.[-1] = \"value\"))) as $p (.;\n  setpath($p; \"ORG-DEV-\" + getpath($p)) )"
    ],
    "identifier": 49863906
  },
  {
    "context": [
      "I'm trying to get a JSON representation of `juju status` output which objectifies the machine, the instance-id, and the unit such that the JSON looks similar to:",
      "It is unclear to me how exactly the value of \"unit-name\" is supposed to be derived, but the following should get you on your way:",
      "def machine($id):\n  first(.applications[]\n    | (.units? // empty)\n    | to_entries[]\n    | select(.value.machine == $id)\n    | .key ) ;\n\n. as $in\n| .machines\n| to_entries[]\n| .key as $key\n| {($key): {\n             \"unit-name\": (.value |.[\"instance-id\"]),\n             \"machine\": ($in|machine($key))\n  \t       } }",
      "With your input, this produces a stream of objects beginning:",
      "{\n  \"0\": {\n    \"unit-name\": \"xxxxxxxxxx\",\n    \"machine\": \"easyrsa/0\"\n  }\n}\n{\n  \"1\": {\n    \"unit-name\": \"xxxxxxxxxx\",\n    \"machine\": \"etcd/0\"\n  }\n}"
    ],
    "utterance": "Produce an object for each machine containing the instance-id and the corresponding unit name from the status output.",
    "expressions": [
      "def machine($id):\n  first(.applications[]\n    | (.units? // empty)\n    | to_entries[]\n    | select(.value.machine == $id)\n    | .key );\n\n. as $in\n| .machines\n| to_entries[]\n| .key as $key\n| {($key): {\n    \"instance-id\": .value[\"instance-id\"],\n    \"unit-name\": ($in|machine($key))\n  } }"
    ],
    "data": [
      {
        "input": {
          "model": {},
          "machines": {
            "0": {
              "instance-id": "i-xxxxxxxxxxxxxx"
            },
            "1": {
              "instance-id": "i-xxxxxxxxxxxxxx"
            }
          },
          "applications": {
            "easyrsa": {
              "units": {
                "easyrsa/0": {
                  "machine": "0"
                }
              }
            },
            "etcd": {
              "units": {
                "etcd/0": {
                  "machine": "1"
                }
              }
            }
          }
        },
        "output": [
          {
            "0": {
              "instance-id": "i-xxxxxxxxxxxxxx",
              "unit-name": "easyrsa/0"
            }
          },
          {
            "1": {
              "instance-id": "i-xxxxxxxxxxxxxx",
              "unit-name": "etcd/0"
            }
          }
        ]
      }
    ],
    "identifier": 50055538
  },
  {
    "context": [
      "\"But this doesn't:\\n\\n    - shell: jq -r '{{ stale_instance_filter }}'\\n      args:\\n        stdin: \\\"{{ asgs_result.stdout }}\\\"\\n\\nI get the following error message: `parse error: Invalid numeric literal at line 1, column 23`\"",
      "\"So, you need to \\\"escape\\\" it.\"",
      "\"But the `string` filter fits perfectly:\"",
      "\"So, the correct way with `stdin` is this:\\n\\n    - shell: jq -r '{{ stale_instance_filter }}'\\n      args:\\n        stdin: \\\"{{ asgs_result.stdout | string }}\\\"\""
    ],
    "utterance": "Apply a filter to select stale instances from asgs_result.stdout using the shell module's stdin argument, ensuring proper escaping for correct parsing.",
    "expressions": [
      "{{ asgs_result.stdout | string }}"
    ],
    "data": [
      {
        "input": {
          "asgs_result": {
            "stdout": "{\"AutoScalingGroupARN\":\"arn:aws:autoscaling:us-east-2:123456:autoScalingGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev\",\"TargetGroupARNs\":[],\"SuspendedProcesses\":[],\"DesiredCapacity\":4,\"Tags\":[{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"dev\",\"Key\":\"Dimension\"},{\"ResourceType\":\"auto-scaling-group\",\"ResouJceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"true\",\"Key\":\"Monitored\"},{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"myrole\",\"Key\":\"Name\"},{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"myrole\",\"Key\":\"Role\"},{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"2035-09-30 18:55:31 +0000\",\"Key\":\"cleaner-destroy-after\"},{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"vpce-2c23ca45\",\"Key\":\"force_s3_endpoint_dependency\"},{\"ResourceType\":\"auto-scaling-group\",\"ResourceId\":\"myrole-dev\",\"PropagateAtLaunch\":true,\"Value\":\"owned\",\"Key\":\"kubernetes.io/cluster/dev\"}],\"EnabledMetrics\":[],\"LoadBalancerNames\":[],\"AutoScalingGroupName\":\"myrole-dev\",\"DefaultCooldown\":300,\"MinSize\":4,\"Instances\":[{\"ProtectedFromScaleIn\":false,\"AvailabilityZone\":\"us-east-2b\",\"InstanceId\":\"i-0141fd35e3cf3ad0a\",\"HealthStatus\":\"Healthy\",\"LifecycleState\":\"InService\",\"LaunchConfigurationName\":\"dev_myrole_20180511171410107500000002\"},{\"ProtectedFromScaleIn\":false,\"AvailabilityZone\":\"us-east-2c\",\"InstanceId\":\"i-01aec2b3546d75190\",\"HealthStatus\":\"Healthy\",\"LifecycleState\":\"InService\",\"LaunchConfigurationName\":\"dev_myrole_20180511171410107500000002\"},{\"ProtectedFromScaleIn\":false,\"AvailabilityZone\":\"us-east-2a\",\"InstanceId\":\"i-0830b227f034d2859\",\"HealthStatus\":\"Healthy\",\"LifecycleState\":\"InService\",\"LaunchConfigurationName\":\"dev_myrole_20180511171410107500000002\"},{\"ProtectedFromScaleIn\":false,\"AvailabilityZone\":\"us-east-2b\",\"InstanceId\":\"i-0f7d847e8c168040b\",\"HealthStatus\":\"Healthy\",\"LifecycleState\":\"InService\",\"LaunchConfigurationName\":\"dev_myrole_20180511171410107500000002\"}],\"MaxSize\":4,\"VPCZoneIdentifier\":\"subnet-c348988e,subnet-79743210,subnet-156ee36e\",\"HealthCheckGracePeriod\":300,\"TerminationPolicies\":[\"Default\"],\"LaunchConfigurationName\":\"dev_myrole_20180511171410107500000002\",\"CreatedTime\":\"2018-02-20T22:35:32.183Z\",\"AvailabilityZones\":[\"us-east-2a\",\"us-east-2b\",\"us-east-2c\"],\"HealthCheckType\":\"EC2\",\"NewInstancesProtectedFromScaleIn\":false}"
          }
        }
      }
    ],
    "identifier": 50109875
  },
  {
    "context": [
      "I need to read these two files, combine primary and secondary numbers for each ID, and make a JSON string like this for each ID.",
      "jq -s --argfile ids cardinals.json '.[0] as $p | .[1] as $s\n   | range(0; $ids|length) as $ix\n   | ($ix+1|tostring) as $i\n   | select($p | has($i) )\n   | {\"text\": (\"for client \" + $ids[$ix] + \".\"),\n      \"pri\": $p[$i],\n      \"sec\": $s[$i] }\n' primary.json secondary.json",
      "jq -s --argfile ids cardinals.json '\n    def apnumber:\n      (tonumber? // null) as $i\n      | if $i and $i >= 0 and $i < 10                             \n        then [\"zero\", \"one\", \"two\", \"three\", \"four\", \"five\", \"six\", \"seven\", \"eight\", \"nine\"][$i]\n        else .\n        end;\n\n   .[0] as $p | .[1] as $s\n   | ($p|keys_unsorted[]) as $i\n   | {\"text\": (\"for client \" + ($i|apnumber) + \".\"),\n      \"pri\": $p[$i],\n      \"sec\": $s[$i] }\n' primary.json secondary.json"
    ],
    "utterance": "For each client ID, produce an object containing the English cardinal form of the ID in the text field, with pri and sec arrays combining primary and secondary values from both input files.",
    "expressions": [
      "jq -s --argfile ids cardinals.json '.[0] as $p | .[1] as $s\n   | range(0; $ids|length) as $ix\n   | ($ix+1|tostring) as $i\n   | select($p | has($i) )\n   | {\"text\": (\"for client \" + $ids[$ix] + \".\"),\n      \"pri\": $p[$i],\n      \"sec\": $s[$i] }\n' primary.json secondary.json",
      "jq -s --argfile ids cardinals.json '\n    def apnumber:\n      (tonumber? // null) as $i\n      | if $i and $i >= 0 and $i < 10                             \n        then [\"zero\", \"one\", \"two\", \"three\", \"four\", \"five\", \"six\", \"seven\", \"eight\", \"nine\"][$i]\n        else .\n        end;\n\n   .[0] as $p | .[1] as $s\n   | ($p|keys_unsorted[]) as $i\n   | {\"text\": (\"for client \" + ($i|apnumber) + \".\"),\n      \"pri\": $p[$i],\n      \"sec\": $s[$i] }\n' primary.json secondary.json"
    ],
    "data": [
      {
        "input": [
          {
            "1": [
              0,
              273,
              546,
              819
            ],
            "2": [
              274,
              1,
              820
            ],
            "3": [
              1016,
              275,
              821
            ]
          },
          {
            "1": [
              342,
              1102,
              608,
              684
            ],
            "2": [
              115,
              191,
              837,
              1559
            ],
            "3": [
              1256,
              116
            ]
          }
        ],
        "output": [
          {
            "text": "for client one.",
            "pri": [
              0,
              273,
              546,
              819
            ],
            "sec": [
              342,
              1102,
              608,
              684
            ]
          },
          {
            "text": "for client two.",
            "pri": [
              274,
              1,
              820
            ],
            "sec": [
              115,
              191,
              837,
              1559
            ]
          },
          {
            "text": "for client three.",
            "pri": [
              1016,
              275,
              821
            ],
            "sec": [
              1256,
              116
            ]
          }
        ]
      }
    ],
    "identifier": 49995039
  }
]