[
  {
    "context": [
      "I can produce a list of objects (VMs) that don't have ansible_host defined.",
      "the problem is how do I print these plus the key for the object itself?",
      "Assuming you are searching for items found in the `._meta.hostvars` object, you can filter the objects by key/value by using something like `with_entries/1`.",
      "$ jq '._meta.hostvars | with_entries(select(.value.ansible_host | not))\n' prod-inventory_201905070920.json"
    ],
    "utterance": "List all key-value pairs under _meta.hostvars where the value does not have ansible_host defined, including their keys.",
    "expressions": [
      "._meta.hostvars | with_entries(select(.value.ansible_host | not))"
    ],
    "identifier": 56024745
  },
  {
    "context": [
      "What I am trying to do is get the first 10 dashboards of type `standard`.",
      "I know I can get *all* the `standard` dashboards with:\n`jq '.dashboards[] | select(.type == \"standard\")'`",
      "If you want the result as an array, you could use `map`:\n\n    .dashboards | map(select(.type==\"standard\")) | .[0:10]",
      "If you wanted the items as a stream, you could write:\n\n    limit(10; .dashboards[] | select(.type==\"standard\"))",
      "If you want the results as an array, simply wrap the above jq expression in square brackets."
    ],
    "utterance": "Get the first 10 dashboards where type equals \"standard\".",
    "expressions": [
      ".dashboards | map(select(.type==\"standard\")) | .[0:10]",
      "[limit(10; .dashboards[] | select(.type==\"standard\"))]"
    ],
    "data": [
      {
        "input": {
          "dashboards": [
            {
              "name": "first",
              "type": "standard"
            },
            {
              "name": "second",
              "type": "custom"
            }
          ]
        },
        "output": [
          {
            "name": "first",
            "type": "standard"
          }
        ]
      }
    ],
    "identifier": 56028679
  },
  {
    "context": [
      "I am trying to find person name who has a subject and it score.",
      "jq: error (at test.txt:39): Cannot index array with string \"Score\"",
      "$ jq -r '.[].result.\"*value*\"[] | select(.Score.English) | \"Name: \\(.name)\", \"Subject: \\(.Score.English)\"' file",
      "Name: ABC",
      "Subject: A+",
      "Name: CDE",
      "Subject: A-"
    ],
    "utterance": "Find the names and English scores of all persons who have an English score.",
    "expressions": [
      ".[].result.\"*value*\"[] | select(.Score.English) | \"Name: \\(.name)\", \"Subject: \\(.Score.English)\""
    ],
    "data": [
      {
        "input": [
          {
            "host": "testserver",
            "hostclass": "Unknown",
            "result": {
              "*value*": [
                {
                  "sessionId": "000001",
                  "name": "ABC",
                  "Age": "21",
                  "Score": {
                    "English": "A+",
                    "Mathematics": "B-",
                    "String Theory": "C+"
                  }
                },
                {
                  "sessionId": "000001",
                  "name": "CDE",
                  "Age": "21",
                  "Score": {
                    "English": "A-",
                    "German": "B-",
                    "French": "C+"
                  }
                },
                {
                  "sessionId": "000001",
                  "name": "EFG",
                  "Age": "21",
                  "Score": {}
                },
                {
                  "sessionId": "000001",
                  "name": "XYZ",
                  "Age": "21"
                }
              ]
            }
          }
        ],
        "output": [
          "Name: ABC",
          "Subject: A+",
          "Name: CDE",
          "Subject: A-"
        ]
      }
    ],
    "identifier": 56027278
  },
  {
    "context": [
      "object=$(echo $object | jq -c \".$city.$medium.$direction[\\\"$date\\\"] |= . + [\\\"$time\\\"]\")",
      "jq -c --arg city \"$city\" \\\n      --arg medium \"$medium\" \\\n      --arg direction \"$direction\" \\\n      --arg date \"$date\" \\\n      --arg time \"$time\" \\\n   '.[$city][$medium][$direction][$date] += [$time]'"
    ],
    "utterance": "For each set of shell variables, add the value of time to the list at object[city][medium][direction][date], passing all variables safely as arguments.",
    "expressions": [
      ".[$city][$medium][$direction][$date] += [$time]"
    ],
    "identifier": 56051594
  },
  {
    "context": [
      "what combination of jq commands could i use to have entries where Statement[].Action is a string and not an array be converted to an array such as the above so i can then run sort on elements inside it.",
      "Or if you want to ensure that `.Action` is always array-valued:\r\n\r\n    map( .Action |= (if type==\"array\" then sort else [.] end) )",
      "So you'll probably want to write something like:\r\n\r\n    jq '.Statement[].Action |= (if type == \"array\" then sort else . end)' file.json"
    ],
    "utterance": "Convert each Statement.Action value to an array if it is a string, so that sorting the elements inside Action does not fail.",
    "expressions": [
      ".Statement[].Action |= (if type==\"array\" then sort else [.] end)"
    ],
    "data": [
      {
        "input": {
          "Statement": [
            {
              "Sid": "Name1",
              "Effect": "Allow",
              "Action": [
                "logs:GetLogEvents",
                "ecs:DeleteCluster",
                "logs:PutRetentionPolicy",
                "logs:PutLogEvents",
                "s3:GetReplicationConfiguration"
              ],
              "Resource": "arn:aws:cognito-idp:*:*:userpool/*",
              "Condition": {
                "ForAllValues:StringEquals": {
                  "aws:ResourceTag/VendorType": "ABC"
                }
              }
            },
            {
              "Sid": "Name2",
              "Effect": "Allow",
              "Action": "cognito-identity:DeleteIdentityPool",
              "Resource": "arn:aws:cognito-identity:*:*:identitypool/*",
              "Condition": {
                "ForAllValues:StringEquals": {
                  "aws:ResourceTag/VendorType": "ABC"
                }
              }
            }
          ]
        },
        "output": {
          "Statement": [
            {
              "Sid": "Name1",
              "Effect": "Allow",
              "Action": [
                "ecs:DeleteCluster",
                "logs:GetLogEvents",
                "logs:PutLogEvents",
                "logs:PutRetentionPolicy",
                "s3:GetReplicationConfiguration"
              ],
              "Resource": "arn:aws:cognito-idp:*:*:userpool/*",
              "Condition": {
                "ForAllValues:StringEquals": {
                  "aws:ResourceTag/VendorType": "ABC"
                }
              }
            },
            {
              "Sid": "Name2",
              "Effect": "Allow",
              "Action": [
                "cognito-identity:DeleteIdentityPool"
              ],
              "Resource": "arn:aws:cognito-identity:*:*:identitypool/*",
              "Condition": {
                "ForAllValues:StringEquals": {
                  "aws:ResourceTag/VendorType": "ABC"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 56032762
  },
  {
    "context": [
      "the data I get from a json",
      "jq -r '.projectName as $project |.environment as $env | .specResults[] |\"ngt_lambda_qa {env=\\\"\\($env)\\\" , spec=\\\"\\(.specHeading|gsub(\"\\\"\";\"\\\\\\\"\") )\\\", result=\\\"\\(.executionStatus)\\\"} \\(.executionTime)\"'",
      "error in prometheus ktext format parsing error in line 1: expected float as value, got \"41584\\r\"",
      "Your data looks like it has a carriage return (the '/r') character at the end of the line. jq is expecting a float value, which the parsed value is not, as it has this character added."
    ],
    "utterance": "Extract executionTime values as numbers without trailing carriage return characters.",
    "expressions": [
      ".specResults[] | \"\\(.specHeading) \\(.executionTime|tonumber)\""
    ],
    "identifier": 56063869
  },
  {
    "context": [
      "My **target** is to get an output **sorted by version**:",
      "How can I get a result sorted-by version number?",
      "If the strings are \"raw\" strings, one per line, then you could use this jq program:",
      "def parse:\n sub(\"alpha\"; \"alpha.\")\n | sub(\"beta\"; \"beta.\") \n | sub(\"gamma\"; \"gamma.\")\n | sub(\"prerelease\"; \"prerelease.\")\n | sub(\"debug\"); \"debug.\")\n | [splits(\"[-.]\")]\n | map(tonumber? // .) ;\n\n[inputs]\n| sort_by(parse)[]",
      "With the sample version numbers, this would produce:\n\n1.2.3.95\n1.2.3.99\n1.2.3.99-beta9\n1.2.3.99-beta10\n1.2.3.101\n1.2.3.103",
      "the result can be achieved without invoking jq a second time by modifying your program to use parse along the lines shown above.  The main part of the jq program would probably look something like this:\n\nmap(.props[\"nuget.version\"]) | sort_by(parse)[]"
    ],
    "utterance": "Return all NuGet package versions associated with nuget.id=MyLib, sorted in ascending order by semantic version, including pre-release identifiers like -beta.",
    "expressions": [
      "def parse: sub(\"alpha\"; \"alpha.\") | sub(\"beta\"; \"beta.\") | sub(\"gamma\"; \"gamma.\") | sub(\"prerelease\"; \"prerelease.\") | sub(\"debug\"; \"debug.\") | [splits(\"[-.]\")] | map(tonumber? // .);\n[inputs] | sort_by(parse)[]",
      "def parse: sub(\"alpha\"; \"alpha.\") | sub(\"beta\"; \"beta.\") | sub(\"gamma\"; \"gamma.\") | sub(\"prerelease\"; \"prerelease.\") | sub(\"debug\"; \"debug.\") | [splits(\"[-.]\")] | map(tonumber? // .);\nmap(.props[\"nuget.version\"]) | sort_by(parse)[]"
    ],
    "data": [
      {
        "input": [
          "1.2.3.101",
          "1.2.3.103",
          "1.2.3.95",
          "1.2.3.99",
          "1.2.3.99-beta10",
          "1.2.3.99-beta9"
        ],
        "output": [
          "1.2.3.95",
          "1.2.3.99",
          "1.2.3.99-beta9",
          "1.2.3.99-beta10",
          "1.2.3.101",
          "1.2.3.103"
        ]
      }
    ],
    "identifier": 56024932
  },
  {
    "context": [
      "I want to convert all `lastUsedTimestamp` values to a date. This works with:",
      "reduce (paths | select(.[-1] == \"lastUsedTimestamp\")) as $p \n  (.;setpath($p; getpath($p) / 1000 | todate))",
      "But what if I had other timestamp keys such as `createdTimestamp` or `startTimestamp` in other places of the object?",
      "I tried\nreduce (paths | select(.[-1] | endswith(\"Timestamp\")) as $p \n  (.;setpath($p; getpath($p) / 1000 | todate))\nor an equivalent with `test` but paths that end with an integer make it fail.",
      "How can I work around this?",
      "To supress errors use `... ?` operator, which is a shorthand for `try ...`.",
      "reduce (paths|select(.[-1]|endswith(\"Timestamp\")?)) as $p\n(.; setpath($p; getpath($p)/1000|todate))",
      "For this type of problem, `walk/1` is often convenient:",
      "walk( if type == \"object\" then with_entries(if .key | endswith(\"Timestamp\") then .value |= (./1000 | todate) else . end) else . end)"
    ],
    "utterance": "Convert all key values ending with 'Timestamp', at any level, from milliseconds since epoch to ISO date strings.",
    "expressions": [
      "reduce (paths|select(.[-1]|endswith(\"Timestamp\")?)) as $p (.; setpath($p; getpath($p)/1000|todate))",
      "walk(if type == \"object\" then with_entries(if .key | endswith(\"Timestamp\") then .value |= (./1000 | todate) else . end) else . end)"
    ],
    "data": [
      {
        "input": {
          "domainId": "hidden",
          "lastUsed": "Thu Oct 04 2018",
          "lastUsedTimestamp": 1538673002460,
          "users": [
            {
              "userId": "hidden",
              "lastUsedTimestamp": 1538673002460
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": 1536087726701
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": 1536086675399,
              "createdTimestamp": 1536086675399
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": 1536182646984,
              "startTimestamp": 1536182646984
            }
          ]
        },
        "output": {
          "domainId": "hidden",
          "lastUsed": "Thu Oct 04 2018",
          "lastUsedTimestamp": "2018-10-04T10:10:02Z",
          "users": [
            {
              "userId": "hidden",
              "lastUsedTimestamp": "2018-10-04T10:10:02Z"
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": "2018-09-04T01:42:06Z"
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": "2018-09-04T01:24:35Z",
              "createdTimestamp": "2018-09-04T01:24:35Z"
            },
            {
              "userId": "hidden",
              "lastUsedTimestamp": "2018-09-05T05:24:06Z",
              "startTimestamp": "2018-09-05T05:24:06Z"
            }
          ]
        }
      }
    ],
    "identifier": 56020478
  },
  {
    "context": [
      "how can I echo the name for each element in the items array? Something like this:\n\n    kbc get pods -o=json | jq -c | jq '.items[].name' | cat",
      "kbc get pods -o=json | jq -r '.items[].name'",
      "Using `-r` tells jq to write *raw* output, thus without quoting the names as JSON strings."
    ],
    "utterance": "Print the value of the name field for each element in the items array.",
    "expressions": [
      ".items[].name"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "name": "a"
            },
            {
              "name": "b"
            },
            {
              "name": "c"
            }
          ]
        },
        "output": [
          "a",
          "b",
          "c"
        ]
      }
    ],
    "identifier": 56064996
  },
  {
    "identifier": 56111140
  },
  {
    "context": [
      "I want to insert new root element on my json with jq, my goal is to manipulate json hierarchy by adding one level before root one:",
      "json example:",
      "{\n \"option1\":true\n}",
      "i want to obtain:",
      "{\n \"root\":\n {\n  \"option1\":true\n }\n}",
      "Put `.` in the spot where you want your input data to be. In that case, that's as the value for which the `root` string is a key.",
      "jq '{\"root\": .}' <<<'{\"option1\": true}'",
      "...properly emits:",
      "{\n  \"root\": {\n    \"option1\": true\n  }\n}"
    ],
    "utterance": "Wrap the original object within a new object under the key 'root'.",
    "expressions": [
      "{ \"root\": . }"
    ],
    "data": [
      {
        "input": {
          "option1": true
        },
        "output": {
          "root": {
            "option1": true
          }
        }
      }
    ],
    "identifier": 56080834
  },
  {
    "context": [
      "I expect to see only 3 lines:\n\"name 2019-05-01 11:00:00.000 50\"\n\"name 2019-05-02 12:00:00.000 40\"\n\"name 2019-05-02 13:00:00.000 30\"",
      "Do something like this instead:\n```\n.[] | .key + \" \" + (.values_over_time.buckets[] | \"\\(.key_as_string) \\(.doc_count)\")\n```",
      "I would write it like so:\n\n    .[] | \"\\(.key) \\(.values_over_time.buckets[] | \\(.key_as_string) \\(.doc_count))\""
    ],
    "utterance": "Print each top-level object's key, each bucket's key_as_string, and doc_count as space-separated lines.",
    "expressions": [
      ".[] | .key + \" \" + (.values_over_time.buckets[] | \"\\(.key_as_string) \\(.doc_count)\")",
      ".[] | \"\\(.key) \\(.values_over_time.buckets[] | \\(.key_as_string) \\(.doc_count))\""
    ],
    "data": [
      {
        "input": [
          {
            "key": "name",
            "doc_count": 1000,
            "values_over_time": {
              "buckets": [
                {
                  "key_as_string": "2019-05-01 11:00:00.000",
                  "key": 1556708400000,
                  "doc_count": 50
                },
                {
                  "key_as_string": "2019-05-02 12:00:00.000",
                  "key": 1556798400000,
                  "doc_count": 40
                },
                {
                  "key_as_string": "2019-05-02 13:00:00.000",
                  "key": 1556802000000,
                  "doc_count": 30
                }
              ]
            }
          }
        ],
        "output": [
          "name 2019-05-01 11:00:00.000 50",
          "name 2019-05-02 12:00:00.000 40",
          "name 2019-05-02 13:00:00.000 30"
        ]
      }
    ],
    "identifier": 56065822
  },
  {
    "context": [
      "jq itself is reading the first line, then inputs (having received that line as *its* input) will read the rest. Typically, you want to use the -n option to prevent jq from doing any reading itself, letting any input or inputs filters do the actual reading.",
      "$ echo -n $'line1\\nline2\\n' | jq -nR 'inputs'\n\"line1\"\n\"line2\"",
      "cat tmp.tsv\nfoo\tbar\tbaz\n1\t2\t3\n4\t5\t6\n$ jq -R 'split(\"\\t\") as $h | [inputs | split(\"\\t\") | [{key: $h[0], value: .[0]}, {key: $h[1], value: .[1]}, {key: $h[2], value: .[2]}] | from_entries]' tmp.tsv\n[\n  {\n    \"foo\": \"1\",\n    \"bar\": \"2\",\n    \"baz\": \"3\"\n  },\n  {\n    \"foo\": \"4\",\n    \"bar\": \"5\",\n    \"baz\": \"6\"\n  }\n]",
      "jq reads the first line and splits it into the array h, then feeds that line to a filter which ignores it but uses inputs to read the rest of the lines, splitting each one up and creating a dict using (repeatedly) the value of $h."
    ],
    "utterance": "Convert tab-delimited records into objects using the first line as field names.",
    "expressions": [
      "jq -R 'split(\"\\t\") as $h | [inputs | split(\"\\t\") | [{key: $h[0], value: .[0]}, {key: $h[1], value: .[1]}, {key: $h[2], value: .[2]}] | from_entries]'"
    ],
    "data": [
      {
        "input": "foo\tbar\tbaz\n1\t2\t3\n4\t5\t6\n",
        "output": [
          {
            "foo": "1",
            "bar": "2",
            "baz": "3"
          },
          {
            "foo": "4",
            "bar": "5",
            "baz": "6"
          }
        ]
      }
    ],
    "identifier": 55995980
  },
  {
    "context": [
      "What I want to get values of all \u201ctext\u201d attributes. However, it can be seen that this JSON is a multi-layered nested structure.",
      "expected result:",
      "Found On:",
      "Name of component",
      "The Problem:",
      "Description of the problem",
      "All you need to do is tweaking the example above a bit to suppress `null`s:",
      "$ jq '..|(.text?)//empty' file",
      "Found On:",
      "Name of component",
      "The Problem:",
      "Description of the problem"
    ],
    "utterance": "Extract all values of the 'text' key from any level of nesting",
    "expressions": [
      "..|(.text?) // empty"
    ],
    "data": [
      {
        "input": {
          "content": [
            {
              "type": "paragraph",
              "content": [
                {
                  "type": "text",
                  "text": "Found On:"
                },
                {
                  "type": "text",
                  "text": "Name of component"
                }
              ]
            },
            {
              "type": "paragraph",
              "content": [
                {
                  "type": "text",
                  "text": "The Problem:"
                },
                {
                  "type": "paragraph",
                  "content": [
                    {
                      "type": "text",
                      "text": "Description of the problem"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "Found On:",
          "Name of component",
          "The Problem:",
          "Description of the problem"
        ]
      }
    ],
    "identifier": 56107616
  },
  {
    "context": [
      "However, what I want is to access both the email and the id in the loop.",
      "You can output each email-ID pair as a comma separated list from JQ, and use read them into variables in a while loop like so:",
      "while IFS=', ' read -r email id; do ... done <<EOF\n$(jq -r '.values[] | \"\\(.email),\\(.id)\"' file)\nEOF",
      "jq -r '.values[] | (.email, .id)'  input.json |\nwhile IFS= read -r email ; do\n    IFS= read -r id \n    echo \"email=$email and id=$id\"\ndone"
    ],
    "utterance": "For each entry in the values array, output both the email and id fields together so they can be accessed simultaneously in a shell loop.",
    "expressions": [
      ".values[] | \"\u001b[31m\\(.email),\\(.id)\u001b[0m\"",
      ".values[] | (.email, .id)"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "email": "user1@domain.com",
              "id": "USER1_ID"
            },
            {
              "email": "user2@domain.com",
              "id": "USER2_ID"
            }
          ]
        },
        "output": [
          "user1@domain.com,USER1_ID",
          "user2@domain.com,USER2_ID"
        ]
      }
    ],
    "identifier": 56081494
  },
  {
    "context": [
      "is there a command that can decompact/decompress it so it's more human readable again? Basically adding newlines in the right places?",
      "`jq .` will decompress it"
    ],
    "utterance": "Pretty-print compacted data to make it more human-readable with appropriate newlines.",
    "expressions": [
      "jq ."
    ],
    "identifier": 56121575
  },
  {
    "context": [
      "You need to request **tags** instead of **releases** from the api and it will work that way. E.g:",
      "curl -sS 'https://api.github.com/repos/WordPress/WordPress/tags' |\n jq -r '.[0].name'",
      "This shows `5.2` to me."
    ],
    "utterance": "Retrieve the first tag name from the WordPress repository tags API",
    "expressions": [
      ".[0].name"
    ],
    "identifier": 56113755
  },
  {
    "context": [
      "With `jq` I have an array of bytes, like `[0, 255, 128, 0, 127]` that I want to convert to a binary file.",
      "It *almost* works like this:\r\n\r\n    jq --raw-output '. | implode' in.json > out.bin\r\n\r\nBut unfortunately it interprets the input as Unicode code points, and writes the result as a UTF-8 string. Is there a binary version of `implode`?",
      "$ jq -j --raw-output 'implode' <<<'[0, 255, 128, 40, 127]'  | iconv -c -f utf-8 -t ISO-8859-16"
    ],
    "utterance": "Convert an array of integers representing bytes to a binary output file, ensuring each integer is treated as a single byte and not as a Unicode code point.",
    "expressions": [
      "implode"
    ],
    "data": [
      {
        "input": [
          0,
          255,
          128,
          40,
          127
        ],
        "output": null
      }
    ],
    "identifier": 56114199
  },
  {
    "context": [
      "I want to read instanceUrl field from JSON to use later in my script.",
      "Try this:\r\n\r\n`instanceUrl=$(echo $orgCreateResult | ./bash-scripts/jq-win64.exe .result.instanceUrl -r)`"
    ],
    "utterance": "Extract the value of the instanceUrl field under the result object from the data.",
    "expressions": [
      ".result.instanceUrl"
    ],
    "data": [
      {
        "input": {
          "status": 0,
          "result": {
            "username": "test-******@example.com",
            "devHubId": "****@**.com",
            "id": "************",
            "createdBy": "*****@**.com",
            "createdDate": "2019-05-13T14:15:32.000+0000",
            "expirationDate": "2019-06-12",
            "status": "Active",
            "edition": "Developer",
            "orgName": "HPESC",
            "accessToken": "************************************",
            "instanceUrl": "https://nosoftware-ruby-2532-dev-ed.cs6.my.salesforce.com",
            "clientId": "PlatformCLI",
            "alias": "mockScreenOrg"
          }
        },
        "output": "https://nosoftware-ruby-2532-dev-ed.cs6.my.salesforce.com"
      }
    ],
    "identifier": 56154422
  },
  {
    "context": [
      "Here is an example of an empty array being returned but no parse error ",
      "`curl -k -s https://api.earningscalendar.net/?date=20190303 | jq -r 'map([.ticker, .when] | join(\", \")) | join(\"\\n\")' | grep -w \"$1\"`",
      "curl -k -s https://api.earningscalendar.net/?date=$newdate | jq -r 'map([.ticker, .when] | join(\", \")) | join(\"\\n\")' | grep -w \"$1\""
    ],
    "utterance": "Extract all values of 'ticker' and 'when', joining each pair with a comma and outputting each pair on a separate line.",
    "expressions": [
      "map([.ticker, .when] | join(\", \")) | join(\"\\n\")"
    ],
    "data": [
      {
        "input": [
          {
            "ticker": "ACB",
            "when": "amc"
          },
          {
            "ticker": "TLRY",
            "when": "amc"
          }
        ],
        "output": "ACB, amc\nTLRY, amc"
      },
      {
        "input": [],
        "output": ""
      }
    ],
    "identifier": 56136673
  },
  {
    "context": [
      "how i can name the files using the `id` value?",
      "jq -cr '.[] | .id, .' big.json | awk 'NR%2{f=$0\".json\";next} {print >f;close(f)}'",
      "jq -c '.[]\n           | (.id | if type == \"number\" then .\n                    else tostring | gsub(\"[^A-Za-z0-9-_]\";\"+\") end), .' |\nawk '\n  function fn(s) { sub(/^\\\"/,\"\",s); sub(/\\\"$/,\"\",s); return s \".json\"; }\n  NR%2{f=fn($0); next} \n  {print >> f; close(f);}\n' "
    ],
    "utterance": "Split an array of objects so that each object is saved to a separate file named after that object's id value.",
    "expressions": [
      ".[] | .id, .",
      ".[] | (.id | if type == \"number\" then . else tostring | gsub(\"[^A-Za-z0-9-_]\";\"+\") end), ."
    ],
    "identifier": 56167046
  },
  {
    "context": [
      "I need to parse the output with jq, but it fails with an error:",
      "parse error: Invalid escape at line 1, column 373",
      "It refers to this: `\\[`",
      "Read it in raw, fix the string then parse it.",
      "$ ... | jq -R 'gsub(\"\\\\\\\\(?<c>[[\\\\]])\"; \"\\\\\\\\\\(.c)\") | fromjson | \"your filter\"'"
    ],
    "utterance": "Parse input where backslashes before square brackets may be invalidly escaped and retrieve field values after making the data valid",
    "expressions": [
      "jq -R 'gsub(\"\\\\\\\\(?<c>[[\\\\]])\"; \"\\\\\\\\\\(.c)\") | fromjson | .output_fields[\"proc.cmdline\"]'"
    ],
    "data": [
      {
        "input": "{\"priority\":\"Debug\",\"rule\":\"Run shell untrusted\",\"time\":\"2019-05-15T07:32:36.597411997Z\", \"output_fields\": {\"evt.time\":1557905556597411997,\"proc.aname[2]\":\"gitlab-mon\",\"proc.aname[3]\":\"runsv\",\"proc.aname[4]\":\"runsvdir\",\"proc.aname[5]\":\"wrapper\",\"proc.aname[6]\":\"docker-containe\",\"proc.aname[7]\":\"docker-containe\",\"proc.cmdline\":\"sh -c pgrep -fl \\\"unicorn.* worker\\[.*?\\]\\\"\",\"proc.name\":\"sh\",\"proc.pcmdline\":\"reactor.rb:249                                                                       \",\"proc.pname\":\"reactor.rb:249\",\"user.name\":null}}",
        "output": "sh -c pgrep -fl \\\"unicorn.* worker\\[.*?\\]\\\""
      }
    ],
    "identifier": 56144431
  },
  {
    "context": [
      "Now I want to combine these statements so that I get their results on consecutive rows, like this:",
      "{ \"index\": { \"_index\": \"main\", \"_type\": \"default\", \"_id\": \"64\" } }",
      "{ \"mainContentOfPage\": \"hidden\", \"informationType\": \"Product\", \"url\": \"hidden\", \"_id\": \"64\" }",
      "{ \"index\": { \"_index\": \"main\", \"_type\": \"default\", \"_id\": \"65\" } }",
      "{ \"mainContentOfPage\": \"hidden\", \"informationType\": \"Product\", \"url\": \"hidden\", \"_id\": \"65\" }",
      "Use a comma (also, I've simplified the key-value selectors to use the shorthand syntax):",
      "jq -c '.hits.hits[] | { index: { _index, _type, _id } }, ._source' main.json"
    ],
    "utterance": "Produce alternating index metadata and source content objects for each hit, on separate lines, for use with the Elasticsearch Bulk API.",
    "expressions": [
      ".hits.hits[] | { index: { _index, _type, _id } }, ._source"
    ],
    "data": [
      {
        "input": {
          "hits": {
            "hits": [
              {
                "_index": "main",
                "_type": "default",
                "_id": "64",
                "_source": {
                  "mainContentOfPage": "hidden",
                  "informationType": "Product",
                  "url": "hidden",
                  "_id": "64"
                }
              },
              {
                "_index": "main",
                "_type": "default",
                "_id": "65",
                "_source": {
                  "mainContentOfPage": "hidden",
                  "informationType": "Product",
                  "url": "hidden",
                  "_id": "65"
                }
              }
            ]
          }
        },
        "output": [
          {
            "index": {
              "_index": "main",
              "_type": "default",
              "_id": "64"
            }
          },
          {
            "mainContentOfPage": "hidden",
            "informationType": "Product",
            "url": "hidden",
            "_id": "64"
          },
          {
            "index": {
              "_index": "main",
              "_type": "default",
              "_id": "65"
            }
          },
          {
            "mainContentOfPage": "hidden",
            "informationType": "Product",
            "url": "hidden",
            "_id": "65"
          }
        ]
      }
    ],
    "identifier": 56164858
  },
  {
    "context": [
      "\"slug: 07afd144` isn't valid JSON and as such cannot be parsed with `jq`. Furthermore, it doesn't contain a `data` property anywhere, so `.data.slug` doesn't make sense.\"",
      "\"jq is a tool for parsing and transforming JSON documents. What you have shown is not legal JSON. It is however a legal YAML document and can be transformed with [`yq`](https://mikefarah.gitbook.io/yq/).\""
    ],
    "utterance": "Extract the value '07afd144' following 'slug:' from the command output.",
    "expressions": [
      "cut -d' ' -f2-",
      "cut -c7-",
      "awk '{print $2}'",
      "sed 's/^slug: //'",
      "grep -o '[^ ]*$'",
      "grep -o '[[:xdigit:]]*$'",
      "yq '.slug'"
    ],
    "data": [
      {
        "input": "slug: 07afd144",
        "output": "07afd144"
      }
    ],
    "identifier": 56169821
  },
  {
    "context": [
      "Trying to figure out how to print only values that are inside \"filter array\", eg the output:\r\n\r\n    [\"a101\",\"a108\"]\r\n    [\"a108\"]\r\n    [\"a99\"]\r\n    [\"a108\"]",
      "map(select(. as $in | [\"a99\",\"a101\",\"a108\"] | contains([$in])))",
      "map(select(any($filter_array[]==.;.)))",
      "($filter | sort) as $sorted\n| intersection(.; $sorted)"
    ],
    "utterance": "For each array, print only elements that are also present in a given filter array: [\"a99\",\"a101\",\"a108\"]",
    "expressions": [
      "map(select(. as $in | [\"a99\",\"a101\",\"a108\"] | contains([$in])))",
      "map(select(any([\"a99\",\"a101\",\"a108\"][] == .; .)))",
      "($filter | sort) as $sorted | intersection(.; $sorted)"
    ],
    "data": [
      {
        "input": [
          [
            "a100",
            "a101",
            "a102",
            "a103",
            "a104",
            "a105",
            "a106",
            "a107",
            "a108"
          ],
          [
            "a100",
            "a102",
            "a103",
            "a106",
            "a107",
            "a108"
          ],
          [
            "a100",
            "a99"
          ],
          [
            "a107",
            "a108"
          ]
        ],
        "output": [
          [
            "a101",
            "a108"
          ],
          [
            "a108"
          ],
          [
            "a99"
          ],
          [
            "a108"
          ]
        ]
      }
    ],
    "identifier": 56172168
  },
  {
    "context": [
      "How can I do these complementary queries at the same time, so that I receive for example: \r\n\r\n    [1,2,3,4], [5,6,7]",
      "One option is to use `reduce`:\r\n```\r\nreduce .[] as $x\r\n([]; if $x < 5 then .[0] += [$x] else .[1] += [$x] end)\r\n```\r\nThis will produce:\r\n```\r\n[[1,2,3,4],[5,6,7]]\r\n```",
      "jq has a built-in filter for grouping by some (possibly multi-valued) criterion:\r\n\r\n    jq -nc '[1,2,3,4,5,6,7] | group_by(. < 5)'\r\n\r\nproduces:\r\n\r\n    [[5,6,7],[1,2,3,4]]"
    ],
    "utterance": "Group numbers into two arrays: those less than 5 and those greater than or equal to 5.",
    "expressions": [
      "reduce .[] as $x ([]; if $x < 5 then .[0] += [$x] else .[1] += [$x] end)",
      "group_by(. < 5)"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          5,
          6,
          7
        ],
        "output": [
          [
            1,
            2,
            3,
            4
          ],
          [
            5,
            6,
            7
          ]
        ]
      }
    ],
    "identifier": 56176686
  },
  {
    "context": [
      "Let&#39;s say I have: `[[1,2], [3,9], [4,2], [], []]`",
      "I would like to know the scripts to get:  - The number of nested lists which are/are not non-empty. ie want to get: `[3,2]`",
      "the first number in the answer should correspond to the number of empty lists (2), and the second number to the rest (3).  That is, the required answer should be `[2,3]`.",
      "group_by(length==0) | map(length)",
      "group_by(length > 0) | map(length)",
      "tabulate(.[] | length==0 | tostring ) | [.[\"true\", \"false\"]]",
      "def tabulate(stream):\n  reduce stream as $s ({}; .[$s] += 1);"
    ],
    "utterance": "Count how many nested lists are empty and how many are not in the input array [[1,2], [3,9], [4,2], [], []], returning the counts in the order [number of empty, number of non-empty].",
    "expressions": [
      "group_by(length > 0) | map(length)",
      "def tabulate(stream): reduce stream as $s ({}; .[$s] += 1); tabulate(.[] | length==0 | tostring ) | [.[\"true\", \"false\"]]"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          [
            3,
            9
          ],
          [
            4,
            2
          ],
          [],
          []
        ],
        "output": [
          2,
          3
        ]
      }
    ],
    "identifier": 56179292
  },
  {
    "context": [
      "To make sure that `curlData` is a valid JSON value with properly escaped special-characters etc., use [tag:jq] for producing it.",
      "curlData=\"$(jq --arg name \"$repoName\" --arg desc \"$repoDescription\" -nc '{name:$name,description:$desc}')\"",
      "curl --data \"$curlData\" \"$apiURL\""
    ],
    "utterance": "Create an object with fields name and description using the values of the variables repoName and repoDescription, ensuring all spaces and special characters are escaped correctly.",
    "expressions": [
      "jq --arg name \"$repoName\" --arg desc \"$repoDescription\" -nc '{name:$name,description:$desc}'"
    ],
    "identifier": 56201393
  },
  {
    "context": [
      "jq: error: syntax error, unexpected '[' ... .[$env] .apps .[$app] .cloudfront_id",
      "jq 1.5 doesn't support `.key.[\"key\"]` syntax (1.6 does though). Drop the dot before `[$app]` and you're good to go:",
      ".[$env].apps[$app].cloudfront_id"
    ],
    "utterance": "Extract the cloudfront_id value for the app myapp within the prod environment, using variables for environment and app names.",
    "expressions": [
      ".[$env].apps[$app].cloudfront_id"
    ],
    "data": [
      {
        "input": {
          "prod": {
            "apps": {
              "myapp": {
                "cloudfront_id": "BINGO-PROD"
              }
            }
          },
          "stg": {
            "apps": {
              "myapp": {
                "cloudfront_id": "BINGO-STG"
              }
            }
          }
        },
        "output": "BINGO-PROD"
      }
    ],
    "identifier": 56219187
  },
  {
    "context": [
      "what if I just want to read from a string like so:\r\n\r\n    jq '.field' \"$my_json\"",
      "You can use a `bash` feature which lets you redirect stdin from a literal string with the `<<<` operator:\r\n\r\n```\r\n$ json='{\"field\": 3}'\r\n$ jq .field <<< \"$json\"\r\n3\r\n```",
      "It of course also works with inline JSON:\r\n\r\n```\r\n$ jq .field <<< '{\"field\": 3}'\r\n3\r\n```",
      "$ jq -n '$in.foo' --argjson in '{\"foo\":\"bar\"}'\n\"bar\"",
      "A third possibility is to read a string from the environment:\r\n\r\n    $ string='{ \"field\": 33 }' jq -n '$ENV.string|fromjson.field'\r\n    33",
      "$ jq -n '$ARGS.positional[0]|fromjson.field' --args '{\"field\": 333}'\n333",
      "A simple call using `-n` should be enough:\r\n\r\n    jq -nr \"${my_json}|.field\"\r\n\r\nexample:\r\n\r\n    > jq -nr '{foo: \"bar\",baz: \"test\"}|.foo'\r\n    bar"
    ],
    "utterance": "Extract the value of the field named 'field' from a data object provided as a string variable.",
    "expressions": [
      "jq .field <<< \"$my_json\"",
      "jq -n '$in.field' --argjson in \"$my_json\"",
      "jq -n '$ENV.my_json|fromjson.field'",
      "jq -n '$ARGS.positional[0]|fromjson.field' --args \"$my_json\"",
      "jq -nr \"$my_json|.field\""
    ],
    "data": [
      {
        "input": {
          "field": 3
        },
        "output": 3
      }
    ],
    "identifier": 56202911
  },
  {
    "context": [
      "I try to filter a JSON file for all \"description\" keys containing the value \"; Since version\" to print their path and the Version contained within that value.",
      "The JSON I'm filtering is from an API and has the \"description\" key on different paths.",
      "Ideally the end result would return a list with entries like this:",
      "{",
      "  \"path\": \"",
      "    [",
      "    \"paths\",",
      "    \"/v4/users/{user_id}/last_admin_rooms\",",
      "    \"get\"",
      "    ]\"",
      "  ,",
      "  \"version\": {",
      "    \"description\": \"Some_Text_We_Dont_Care_About; Since version 4.10.2 Some_More_Text_We_Dont_Care_About\"",
      "  }",
      "}",
      "curl $api | jq 'paths(objects and (.description|index(\"; Since version\")))'",
      "Here's an excerpt/example what the input looks like:",
      "{",
      "  \"paths\": {",
      "    \"/v4/config/info/defaults\": {",
      "      \"get\": {",
      "        \"description\": \"SomeText; Since version 4.6.0 SomeMoreText\",",
      "      }",
      "    }",
      "  },",
      "  \"definitions\": {",
      "    \"GeneralSettings\": {",
      "      \"properties\": {",
      "        \"s3TagsEnabled\": {",
      "          \"description\": \"Defines if S3 tags are enabled; Since version 4.9.0 NEW\"",
      "        }",
      "      }",
      "    }",
      "  }",
      "}"
    ],
    "utterance": "List all paths and their corresponding description values where the description contains '; Since version', pairing each matching path with its description.",
    "expressions": [
      "paths as $p | getpath($p) | select(type==\"object\" and has(\"description\") and (.description|test(\"; Since version\"))) | {path: $p, version: {description: .description}}",
      "def find_paths(obj; p):\n  if (obj|type) == \"object\" and (obj|has(\"description\")) and (obj.description|test(\"; Since version\")) then\n    [{path: p, version: {description: obj.description}}]\n  else\n    (obj| paths(scalars) as $leafpath | getpath($leafpath) | select((type==\"object\" and has(\"description\")) and (.description|test(\"; Since version\"))) | [{path: p+$leafpath[0:-1], version: {description: .description}}]) // []\n  end;\nreduce paths(scalars) as $p ([]; . + (find_paths(getpath($p); $p[0:-1])))"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/v4/config/info/defaults": {
              "get": {
                "description": "SomeText; Since version 4.6.0 SomeMoreText"
              }
            }
          },
          "definitions": {
            "GeneralSettings": {
              "properties": {
                "s3TagsEnabled": {
                  "description": "Defines if S3 tags are enabled; Since version 4.9.0 NEW"
                }
              }
            }
          }
        },
        "output": [
          {
            "path": [
              "paths",
              "/v4/config/info/defaults",
              "get"
            ],
            "version": {
              "description": "SomeText; Since version 4.6.0 SomeMoreText"
            }
          },
          {
            "path": [
              "definitions",
              "GeneralSettings",
              "properties",
              "s3TagsEnabled"
            ],
            "version": {
              "description": "Defines if S3 tags are enabled; Since version 4.9.0 NEW"
            }
          }
        ]
      }
    ],
    "identifier": 56108239
  },
  {
    "context": [
      "How can I flatten the following json into csv format? The problem I am facing is that this json contains values in places of keys, and all the examples and tutorials that I have seen show how to handle json with keys and values.",
      "JSON: This is what I currently have",
      "{\n  \"AE\": {\n    \"424,2\": \"Etisalat\",\n    \"424,3\": \"DU\"\n  },\n  \"AF\": {\n    \"412,50\": \"Etisalat\"\n  }\n}",
      "CSV: This is what I would like to have as output",
      "\"AE\",\"424,2\",\"Etisalat\"\n\"AE\",\"424,3\",\"DU\"\n\"AF\",\"412,50\",\"Etisalat\"",
      "paths(scalars) as $p | $p + [getpath($p)] | @csv",
      "`paths(scalars)` finds paths to non-iterable values and lists them as arrays (e.g `[\"AE\",\"424,4\"]`),",
      "`getpath($p)` returns the value at path represented by `$p`.",
      "Note that `-r/--raw-output` option is required for proper CSV output."
    ],
    "utterance": "Flatten a nested structure where each top-level key maps to objects whose keys are field names and values are data entries, producing rows of [top-level key, nested key, value] in CSV format.",
    "expressions": [
      "paths(scalars) as $p | $p + [getpath($p)] | @csv"
    ],
    "data": [
      {
        "input": {
          "AE": {
            "424,2": "Etisalat",
            "424,3": "DU"
          },
          "AF": {
            "412,50": "Etisalat"
          }
        },
        "output": "\"AE\",\"424,2\",\"Etisalat\"\n\"AE\",\"424,3\",\"DU\"\n\"AF\",\"412,50\",\"Etisalat\""
      }
    ],
    "identifier": 56207217
  },
  {
    "context": [
      "Here is my json string : \r\n\r\n    {  \r\n       \"all\":[  \r\n          {  \r\n                \"id\":\"51a\"\r\n          },\r\n          {  \r\n                \"id\":\"52b\"\r\n          },\r\n          {  \r\n                \"id\":\"53c\"\r\n          }\r\n        ]\r\n    }",
      "I expect to get the following output :\r\n\r\n    51a\r\n    52b\r\n    53c",
      "Like that:\r\n\r\n    for id in $(jq -r '.all[].id' <<< \"$json\"); do\r\n        echo \"$id\"\r\n    done",
      "Notice that `-r` option has to be used if you want to remove double quotes:"
    ],
    "utterance": "Extract all id values from each object in the all array where each object contains an id field.",
    "expressions": [
      ".all[].id",
      ".all | .[].id"
    ],
    "data": [
      {
        "input": {
          "all": [
            {
              "id": "51a"
            },
            {
              "id": "52b"
            },
            {
              "id": "53c"
            }
          ]
        },
        "output": [
          "51a",
          "52b",
          "53c"
        ]
      }
    ],
    "identifier": 56220762
  },
  {
    "context": [
      "I wrote following commands:",
      "jq -n 'reduce empty as $e (0; .)'",
      "jq -n 'foreach empty as $e (0; .; .)'",
      "$ jq -n 'reduce empty as $e (0; .)'\n0",
      "$ jq -n 'foreach empty as $e (0; .; .)'\n$",
      "Reduce on the other hand also has no iterations so no changes are made to the initial seed (`0`) which is then returned.",
      "Foreach is similar to reduce but is different in that it doesn't return the final result, but rather it returns all the intermediate results for each value instead.",
      "Since no iterations are made in the foreach call, no results are generated."
    ],
    "utterance": "Compare the output when applying reduce and foreach with an empty input and initial value 0.",
    "expressions": [
      "reduce empty as $e (0; .)",
      "foreach empty as $e (0; .; .)"
    ],
    "data": [
      {
        "input": null,
        "output": [
          {
            "expression": "reduce empty as $e (0; .)",
            "output": 0
          },
          {
            "expression": "foreach empty as $e (0; .; .)",
            "output": []
          }
        ]
      }
    ],
    "identifier": 56225179
  },
  {
    "context": [
      "what i need to do, is to find if each value found in serialno, exists in serialnopool. If this holds TRUE, then i need a way, to have the values of serialno, that were found in serialnopool, grouped, along with their corresponding row ids.",
      "example output of serialno value **11079851** that exists in serialnopool: \r\n\r\n**11079851: 098, 798**",
      "Assuming that by \"exists in serialnopool\" you mean \"occurs at least once in the set of serialnopool values\", the following is a solution provided that your jq is version 1.5 or higher:",
      "map(.serialnopool) as $snp\n| (INDEX( group_by(.serialno)[]; .[0].serialno|tostring)\n   | map_values(map(.rowid))) as $dict\n| (map(.serialno) | unique[]) as $sn\n| if IN($sn; $snp[])\n  then \"\\($sn): \" + ($dict[$sn|tostring] | join(\", \"))\n  else empty end"
    ],
    "utterance": "List each value, along with its corresponding row ids, where serialno occurs in any serialnopool value.",
    "expressions": [
      "map(.serialnopool) as $snp\n| (INDEX( group_by(.serialno)[]; .[0].serialno|tostring)\n   | map_values(map(.rowid))) as $dict\n| (map(.serialno) | unique[]) as $sn\n| if IN($sn; $snp[])\n  then \"\\($sn): \" + ($dict[$sn|tostring] | join(\", \"))\n  else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "rowid": "098",
            "serialno": 11079851,
            "serialnopool": 11079851
          },
          {
            "rowid": 110,
            "serialno": 11089385,
            "serialnopool": 25853201
          },
          {
            "rowid": 118,
            "serialno": 11089385,
            "serialnopool": 22412115
          },
          {
            "rowid": 798,
            "serialno": 11079851,
            "serialnopool": 22412115
          },
          {
            "rowid": "",
            "serialno": "",
            "serialnopool": 5423
          },
          {
            "rowid": "",
            "serialno": "",
            "serialnopool": 5421312
          }
        ],
        "output": [
          "11079851: 098, 798"
        ]
      }
    ],
    "identifier": 56222287
  },
  {
    "context": [
      "the problem is i need to count how many mac address has an impairment name of \"docsis-level\"",
      "Count of mac with docsis-level = x number",
      "count(.. | objects | select( has(\"impaired\") and .name == \"docsis-level\"))",
      "count(.. | .impairments? // empty | .[] | select( .name? == \"docsis-level\"))",
      "count(.[] | .impairments[] | select( .name == \"docsis-level\"))"
    ],
    "utterance": "Count the number of entries where at least one impairment has name equal to 'docsis-level'.",
    "expressions": [
      "count(.. | objects | select( has(\"impaired\") and .name == \"docsis-level\"))",
      "count(.. | .impairments? // empty | .[] | select( .name? == \"docsis-level\"))",
      "count(.[] | .impairments[] | select( .name == \"docsis-level\"))"
    ],
    "data": [
      {
        "input": [
          {
            "mac": "BC:2E:48:D7:E6:EF",
            "timestamp": "2019-05-06T06:06:13.568Z",
            "impairments": [
              {
                "name": "level",
                "impaired": true,
                "startFrequency": 76.279,
                "stopFrequency": 953.721,
                "level": 52.4
              },
              {
                "name": "tilt",
                "impaired": false,
                "startFrequency": 123,
                "stopFrequency": 795,
                "level": 8.28
              },
              {
                "name": "roll-off",
                "impaired": false,
                "startFrequency": 699,
                "stopFrequency": 795,
                "level": 0
              },
              {
                "name": "suck-out",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "peak",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "ripple",
                "impaired": true,
                "startFrequency": 119.932,
                "stopFrequency": 798.037,
                "level": 0
              },
              {
                "name": "fm-ingress",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "lte-ingress",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "adjacency",
                "impaired": false,
                "startFrequency": 179.982,
                "stopFrequency": 186.018,
                "level": 1.3
              },
              {
                "name": "channel-snr",
                "impaired": false,
                "startFrequency": 141.025,
                "stopFrequency": 141.025,
                "level": 33.7
              },
              {
                "name": "channel-level",
                "impaired": true,
                "startFrequency": 639.014,
                "stopFrequency": 639.014,
                "level": 27.47
              },
              {
                "name": "channel-tilt",
                "impaired": false,
                "startFrequency": 165.107,
                "stopFrequency": 165.107,
                "level": 1.21
              },
              {
                "name": "channel-icfr",
                "impaired": false,
                "startFrequency": 752.803,
                "stopFrequency": 752.803,
                "level": 6.4
              },
              {
                "name": "channel-guard-band",
                "impaired": true,
                "startFrequency": 531.025,
                "stopFrequency": 531.025,
                "level": -32.33
              },
              {
                "name": "correctable-cer",
                "impaired": false,
                "startFrequency": 603,
                "stopFrequency": 603,
                "level": 0
              },
              {
                "name": "uncorrectable-cer",
                "impaired": false,
                "startFrequency": 603,
                "stopFrequency": 603,
                "level": 0
              },
              {
                "name": "docsis-snr",
                "impaired": false,
                "startFrequency": 639,
                "stopFrequency": 639,
                "level": 38.9
              },
              {
                "name": "docsis-level",
                "impaired": false,
                "startFrequency": 633,
                "stopFrequency": 633,
                "level": 7.8
              }
            ],
            "ofdmData": {
              "numChannels": 0,
              "numProfiles": 0
            }
          },
          {
            "mac": "BC:2E:48:D7:EA:24",
            "timestamp": "2019-05-06T06:06:13.536Z",
            "impairments": [
              {
                "name": "level",
                "impaired": true,
                "startFrequency": 76.279,
                "stopFrequency": 953.721,
                "level": 52.6
              },
              {
                "name": "tilt",
                "impaired": false,
                "startFrequency": 123,
                "stopFrequency": 795,
                "level": 8.69
              },
              {
                "name": "roll-off",
                "impaired": false,
                "startFrequency": 699,
                "stopFrequency": 795,
                "level": 0
              },
              {
                "name": "suck-out",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "peak",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "ripple",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "fm-ingress",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "lte-ingress",
                "impaired": false,
                "startFrequency": 0,
                "stopFrequency": 0,
                "level": 0
              },
              {
                "name": "adjacency",
                "impaired": false,
                "startFrequency": 179.982,
                "stopFrequency": 186.018,
                "level": 1.4
              },
              {
                "name": "channel-snr",
                "impaired": false,
                "startFrequency": 141.025,
                "stopFrequency": 141.025,
                "level": 36.1
              },
              {
                "name": "channel-level",
                "impaired": true,
                "startFrequency": 639.014,
                "stopFrequency": 639.014,
                "level": 27.46
              },
              {
                "name": "channel-tilt",
                "impaired": false,
                "startFrequency": 687.002,
                "stopFrequency": 687.002,
                "level": 0.65
              },
              {
                "name": "channel-icfr",
                "impaired": false,
                "startFrequency": 392.861,
                "stopFrequency": 392.861,
                "level": 5.4
              },
              {
                "name": "channel-guard-band",
                "impaired": true,
                "startFrequency": 507.061,
                "stopFrequency": 507.061,
                "level": -32.9
              },
              {
                "name": "correctable-cer",
                "impaired": false,
                "startFrequency": 693,
                "stopFrequency": 693,
                "level": 0
              },
              {
                "name": "uncorrectable-cer",
                "impaired": false,
                "startFrequency": 693,
                "stopFrequency": 693,
                "level": 0
              },
              {
                "name": "docsis-snr",
                "impaired": false,
                "startFrequency": 651,
                "stopFrequency": 651,
                "level": 39.3
              },
              {
                "name": "docsis-level",
                "impaired": false,
                "startFrequency": 651,
                "stopFrequency": 651,
                "level": 8
              }
            ],
            "ofdmData": {
              "numChannels": 0,
              "numProfiles": 0
            }
          }
        ],
        "output": 2
      }
    ],
    "identifier": 56000443
  },
  {
    "context": [
      "I want to change the value of `objA.objB.propA` only for the object in `anArrayOfObjs` where `title == \"welcome\"`.",
      ".path.to.anArrayOfObjs |= map(\n  select(.title == \"welcome\").objA.objB.propA = \"new value\"\n)"
    ],
    "utterance": "Change the value of objA.objB.propA to \"new value\" only for the object in anArrayOfObjs where title equals \"welcome\" while keeping the rest of the data unchanged.",
    "expressions": [
      ".anArrayOfObjs |= map(if .title == \"welcome\" then .objA.objB.propA = \"new value\" else . end)"
    ],
    "data": [
      {
        "input": {
          "propA": "valA",
          "anArrayOfObjs": [
            {
              "title": "blah",
              "objA": {
                "objB": {
                  "propA": "valA",
                  "propB": "valB"
                }
              }
            },
            {
              "title": "welcome",
              "objA": {
                "objB": {
                  "propA": "valA",
                  "propC": "valC"
                }
              }
            },
            {
              "objA": {
                "objB": {
                  "propA": "valA",
                  "propD": "valD"
                }
              }
            }
          ]
        },
        "output": {
          "propA": "valA",
          "anArrayOfObjs": [
            {
              "title": "blah",
              "objA": {
                "objB": {
                  "propA": "valA",
                  "propB": "valB"
                }
              }
            },
            {
              "title": "welcome",
              "objA": {
                "objB": {
                  "propA": "new value",
                  "propC": "valC"
                }
              }
            },
            {
              "objA": {
                "objB": {
                  "propA": "valA",
                  "propD": "valD"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 56222913
  },
  {
    "context": [
      "The third object doesnot have a timestamp on it. How could I return all the object only have a timestamp on it. Like the following:",
      "map( select ( .values | has(\"timestamp\")? ))",
      "Working example:\n`[ .[] | select (.values | has(\"timestamp\")?) ]`",
      "Or alternative:\n`[ .[] | select (.values.timestamp?) ]`"
    ],
    "utterance": "Return all objects in the array whose 'values' field contains a 'timestamp' key.",
    "expressions": [
      "map(select(.values | has(\"timestamp\")?))",
      "[ .[] | select(.values | has(\"timestamp\")?) ]",
      "[ .[] | select(.values.timestamp?) ]"
    ],
    "data": [
      {
        "input": [
          {
            "dimensions": "helloworld",
            "metrics": "sum(is_error)",
            "values": {
              "timestamp": 1558322460000,
              "value": "0.0"
            }
          },
          {
            "dimensions": "helloworld",
            "metrics": "sum(is_error)",
            "values": {
              "timestamp": 1558322160000,
              "value": "0.0"
            }
          },
          {
            "dimensions": "helloworld",
            "metrics": "sum(is_error)",
            "values": "3423.25"
          }
        ],
        "output": [
          {
            "dimensions": "helloworld",
            "metrics": "sum(is_error)",
            "values": {
              "timestamp": 1558322460000,
              "value": "0.0"
            }
          },
          {
            "dimensions": "helloworld",
            "metrics": "sum(is_error)",
            "values": {
              "timestamp": 1558322160000,
              "value": "0.0"
            }
          }
        ]
      }
    ],
    "identifier": 56231167
  },
  {
    "context": [
      "Im executing a 'curl' operation and keeping the JSON response on a variable.",
      "Because I need to extract multiple values from this response I want to pass the variable to jq command instead of the curl operation (avoid multiple requests).",
      "JSON=$(curl ${URL})",
      "PARAM=$(JSON | jq -r '.param_one.val')",
      "PARAM=$( echo jq -r '.param_one.val' << \"${JSON}\" )"
    ],
    "utterance": "Extract the value of '.param_one.val' from a variable containing the response.",
    "expressions": [
      "echo \"$JSON\" | jq -r '.param_one.val'"
    ],
    "identifier": 56295554
  },
  {
    "context": [
      "For any future readers. To assign the output of jq to a variable in a Bash script, you can use the following general syntax:",
      "name=$(jq -r '.name' data.json)",
      "age=$(jq -r '.age' data.json)"
    ],
    "utterance": "Extract the value of the 'name' and 'age' fields and assign them to separate shell variables for later use in a script.",
    "expressions": [
      "name=$(jq -r '.name' data.json)",
      "age=$(jq -r '.age' data.json)"
    ],
    "data": [
      {
        "input": {
          "name": "John",
          "age": 30
        },
        "output": {
          "name": "John",
          "age": 30
        }
      }
    ],
    "identifier": 56331695
  },
  {
    "context": [
      "You can add additional elements simply with\n\n    jq '. + [\"item2\"]' myArray.json",
      "which should result in\n\n    [\n      \"item1\",\n      \"item2\"\n    ]"
    ],
    "utterance": "Append the string value \"item2\" to a file containing [\"item1\"] resulting in [\"item1\", \"item2\"].",
    "expressions": [
      ". + [\"item2\"]"
    ],
    "data": [
      {
        "input": [
          "item1"
        ],
        "output": [
          "item1",
          "item2"
        ]
      }
    ],
    "identifier": 56351164
  },
  {
    "context": [
      "How can I restrict the indentation?",
      "There is currently no way to instruct jq to preserve the indentation style *per se*, but the `--indent N` and `--tab` command-line options give limited control over the style of indentation.  Thus, in the particular case given, one could achieve the desired effect using `--indent 4`."
    ],
    "utterance": "Control the number of spaces used for indentation in the output by specifying an indentation level of 4 spaces.",
    "expressions": [
      "jq --indent 4 .name=\"xyz\""
    ],
    "data": [
      {
        "input": {
          "name": "abc",
          "private": true,
          "version": "1.0.0",
          "description": "UI",
          "dependencies": {
            "xyz": "9.11",
            "abc": "5.0.0"
          }
        },
        "output": "{\n    \"name\": \"xyz\",\n    \"private\": true,\n    \"version\": \"1.0.0\",\n    \"description\": \"UI\",\n    \"dependencies\": {\n        \"xyz\": \"9.11\",\n        \"abc\": \"5.0.0\"\n    }\n}"
      }
    ],
    "identifier": 56339865
  },
  {
    "context": [
      "I'm looking for the cleanest way to do the following in JQ",
      "Input:\n{\n   \"TopKey1\":{\n      \"some_key\":\"some_value\"\n   },\n   \"TopKey2\":{\n      \"some_key2\":\"some_value2\"\n   },\n   \"KeytoSearch\":[\n      {\n         \"_id\":\"sdf\",\n         \"non_relevant_key1\":\"val\"\n      },\n      {\n         \"_id\":\"sdfdsdf\",\n         \"non_relevant_key2\":\"val\"\n      },\n      {\n         \"_id\":\"sgf\",\n         \"non_relevant_key3\":\"val\"\n      }\n   ]\n}",
      "Output:\n{\n   \"TopKey1\":{\n      \"some_key\":\"some_value\"\n   },\n   \"TopKey2\":{\n      \"some_key2\":\"some_value2\"\n   },\n   \"KeytoSearch\":[\n      {\n         \"non_relevant_key1\":\"val\"\n      },\n      {\n         \"non_relevant_key2\":\"val\"\n      },\n      {\n         \"non_relevant_key3\":\"val\"\n      }\n   ]\n}",
      "jq 'del(.KeytoSearch[]._id)'",
      ".Keytosearch |= map( del(._id) )"
    ],
    "utterance": "Remove the _id key from each object in the KeytoSearch array while leaving other fields and top-level keys unchanged.",
    "expressions": [
      "del(.KeytoSearch[]._id)",
      ".KeytoSearch |= map(del(._id))"
    ],
    "data": [
      {
        "input": {
          "TopKey1": {
            "some_key": "some_value"
          },
          "TopKey2": {
            "some_key2": "some_value2"
          },
          "KeytoSearch": [
            {
              "_id": "sdf",
              "non_relevant_key1": "val"
            },
            {
              "_id": "sdfdsdf",
              "non_relevant_key2": "val"
            },
            {
              "_id": "sgf",
              "non_relevant_key3": "val"
            }
          ]
        },
        "output": {
          "TopKey1": {
            "some_key": "some_value"
          },
          "TopKey2": {
            "some_key2": "some_value2"
          },
          "KeytoSearch": [
            {
              "non_relevant_key1": "val"
            },
            {
              "non_relevant_key2": "val"
            },
            {
              "non_relevant_key3": "val"
            }
          ]
        }
      }
    ],
    "identifier": 56232429
  },
  {
    "context": [
      "The key `ext-118-21-8-0-29` is dynamic it will change the next time and I don't know the exact value, that's why I need to use wildcard. I need to get the value of the key `addr` where version is `4`.",
      ".details.addresses[][] | select(.version == 4).addr",
      ".details.addresses\r\n    | to_entries[]\r\n    | select(.key|startswith(\"ext\"))\r\n    | .value[]\r\n    | select(.version == 4)\r\n    | .addr",
      ".details.addresses\r\n    | ..\r\n    | objects\r\n    | select(.version==4)\r\n    | .addr"
    ],
    "utterance": "Select the addr value from any dynamically named addresses entry where version equals 4.",
    "expressions": [
      ".details.addresses[][] | select(.version == 4).addr",
      ".details.addresses | to_entries[] | select(.key|startswith(\"ext\")) | .value[] | select(.version == 4) | .addr",
      ".details.addresses | .. | objects | select(.version==4) | .addr"
    ],
    "data": [
      {
        "input": {
          "details": {
            "car": "bmw",
            "addresses": {
              "ext-118-21-8-0-29": [
                {
                  "version": 4,
                  "addr": "89 Psr"
                },
                {
                  "version": 6,
                  "addr": "56 apT"
                }
              ]
            }
          }
        },
        "output": "89 Psr"
      }
    ],
    "identifier": 56355822
  },
  {
    "context": [
      "I want to replace \"0.279.0-b1-abc-1234-0716.4567\" with \"0.279.0-b1-abc-1234-0716.9856\" in all places.",
      "I am looking for something like this\n   jq '.dependencies[.[\"@gx/[a-z]*\"] |= (if . == \"^(\\d+\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\.[0-9]*$\" then \"0.279.0-b1-abc-1234-0716.9856\" else . end)' info.json",
      "The above approaches can all be used in the case of regex searches too, e.g. the last case would become:\n\n    .dependencies |= with_entries(\n      if (.key | test(\"@gx/[a-z]*\"))\n          and (.value | test(\"^(\\\\d+\\\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\\\.[0-9]*$\"))\n      then .value = \"0.279.0-b1-abc-1234-0716.9856\" else . end)",
      "Note that the regex strings must be JSON strings, and hence the doubling of backslashes."
    ],
    "utterance": "Replace all dependency values with '0.279.0-b1-abc-1234-0716.9856' where the key matches '@gx/[a-z]*' and the value matches the version pattern '^(\\d+\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\.[0-9]*$'.",
    "expressions": [
      ".dependencies |= with_entries( if (.key | test(\"@gx/[a-z]*\")) and (.value | test(\"^(\\\\d+\\\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\\\.[0-9]*$\")) then .value = \"0.279.0-b1-abc-1234-0716.9856\" else . end )"
    ],
    "data": [
      {
        "input": {
          "license": " See license.md",
          "dependencies": {
            "@gx/core": "0.279.0-b1-abc-1234-0716.4567",
            "@gx/api": "0.279.0-b1-abc-1234-0716.4567",
            "@gx/name": "0.279.0-b1-abc-1234-0716.4567"
          }
        },
        "output": {
          "license": " See license.md",
          "dependencies": {
            "@gx/core": "0.279.0-b1-abc-1234-0716.9856",
            "@gx/api": "0.279.0-b1-abc-1234-0716.9856",
            "@gx/name": "0.279.0-b1-abc-1234-0716.9856"
          }
        }
      }
    ],
    "identifier": 56274128
  },
  {
    "context": [
      "Trying to filter the Tor network's relay consensus (https://onionoo.torproject.org/details) based on whether a relay is \"Running\" and if it has a \"Fast\" flag or not in order to make another json made up of the selected relays.",
      "Possibly even a more concise version that only lists certain elements of each relay (nickname, fingerprint, etc).",
      "This filter will select relays with `Running` and `Fast` flags and yield an array of objects containing only `nickname` and `fingerprint` fields, tweak it to meet your requirements.",
      "```\n.relays | map(select(.flags | index(\"Running\") and index(\"Fast\")) | { nickname, fingerprint })\n```"
    ],
    "utterance": "Select relays that have both 'Running' and 'Fast' flags and produce a list of their nickname and fingerprint fields.",
    "expressions": [
      ".relays | map(select(.flags | index(\"Running\") and index(\"Fast\")) | { nickname, fingerprint })"
    ],
    "identifier": 56373900
  },
  {
    "context": [
      "And I want to read it like this:",
      "how can parse the host and port from the item?",
      "but is there a way to do it without using stdin?",
      "jq -n --argjson ci \"$connection_info\" -cr '$ci | .values[] | \"\\(.host) \\(.port)\"' |"
    ],
    "utterance": "Extract each object's host and port from a variable containing data, without reading from standard input.",
    "expressions": [
      "jq -n --argjson ci \"$connection_info\" -cr '$ci | .values[] | \"\\(.host) \\(.port)\"'"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "host": "xxx",
              "port": 3939
            },
            {
              "host": "yyy",
              "port": 7373
            }
          ]
        },
        "output": [
          "xxx 3939",
          "yyy 7373"
        ]
      }
    ],
    "identifier": 56386009
  },
  {
    "context": [
      "I'd like to get the unique `srcPath` printed once, and the associated `references`.",
      "I don't want to see those. (referring to empty records)",
      "I'd really like a csv with:\n\n`srcPath`, perhaps a different field like `published`, and first `reference`, second `reference`, third `reference`, etc. -- associated `references` array as consecutive comma separated values on the same line",
      "We group the pages by srcPath and map each group into an array that contains the srcPath and published of the first element of the group as well as the references of each element of the group. Each of these arrays will be a row in the CSV result.",
      "jq --raw-output '.pages | group_by(.srcPath)[] | [.[0].srcPath, .[0].published, .[].references[]] | @csv'"
    ],
    "utterance": "Output a CSV where each row contains a unique srcPath, its published value, and all associated references in order, ignoring empty pages.",
    "expressions": [
      ".pages | group_by(.srcPath)[] | [.[0].srcPath, .[0].published, .[].references[]] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "pages": [
              {
                "srcPath": "/content/dam/foo/about-bar/pdf/theplan.pdf",
                "srcTitle": "theplan.pdf",
                "path": "/content/foo/en/about-bar/the-plan-and-vision",
                "title": "the Plan and Vision",
                "references": [
                  "/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/image/link",
                  "/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/textboximg/boxFtr",
                  "/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content1/textboximg/text"
                ],
                "published": false,
                "isPage": "true"
              }
            ]
          },
          {
            "pages": []
          },
          {
            "pages": []
          },
          {
            "pages": [
              {
                "srcPath": "/content/dam/foo/about-bar/photos/rayDavis.PNG",
                "srcTitle": "rayDavis.PNG",
                "path": "/content/foo/en/about-bar",
                "title": "About bar",
                "references": [
                  "/content/foo/en/about-bar/jcr:content/content1B/promos_1/image/fileReference"
                ],
                "published": true,
                "isPage": "true"
              },
              {
                "srcPath": "/content/dam/foo/about-bar/photos/rayDavis.PNG",
                "srcTitle": "rayDavis.PNG",
                "path": "/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis",
                "title": "ray moose Davis",
                "references": [
                  "/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis/jcr:content/content1/textboximg/fileReference"
                ],
                "published": true,
                "isPage": "true"
              },
              {
                "srcPath": "/content/dam/foo/about-bar/photos/rayDavis.PNG",
                "srcTitle": "rayDavis.PNG",
                "path": "/content/foo/en/about-bar/monkey-development/tales-of-giving",
                "title": "tales of Giving",
                "references": [
                  "/content/foo/en/about-bar/monkey-development/tales-of-giving/jcr:content/content1/textboximg_2/fileReference"
                ],
                "published": true,
                "isPage": "true"
              }
            ]
          },
          {
            "pages": [
              {
                "srcPath": "/content/dam/foo/about-bar/pdf/foo_19thNewsletter.pdf",
                "srcTitle": "foo_19thNewsletter.pdf",
                "path": "/content/foo/en/gremlins/stay-tuned",
                "title": "Stay tuned",
                "references": [
                  "/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg/text"
                ],
                "published": true,
                "isPage": "true"
              }
            ]
          },
          {
            "pages": [
              {
                "srcPath": "/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf",
                "srcTitle": "barNews_fall1617.pdf",
                "path": "/content/foo/en/gremlins",
                "title": "gremlins",
                "references": [
                  "/content/foo/en/gremlins/jcr:content/content2C/textboximg_114671747/text"
                ],
                "published": true,
                "isPage": "true"
              },
              {
                "srcPath": "/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf",
                "srcTitle": "barNews_fall1617.pdf",
                "path": "/content/foo/en/gremlins/stay-tuned",
                "title": "Stay tuned",
                "references": [
                  "/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg_0/text"
                ],
                "published": true,
                "isPage": "true"
              }
            ]
          }
        ],
        "output": [
          "\"/content/dam/foo/about-bar/pdf/theplan.pdf\",false,\"/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/image/link\",\"/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/textboximg/boxFtr\",\"/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content1/textboximg/text\"",
          "\"/content/dam/foo/about-bar/photos/rayDavis.PNG\",true,\"/content/foo/en/about-bar/jcr:content/content1B/promos_1/image/fileReference\",\"/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis/jcr:content/content1/textboximg/fileReference\",\"/content/foo/en/about-bar/monkey-development/tales-of-giving/jcr:content/content1/textboximg_2/fileReference\"",
          "\"/content/dam/foo/about-bar/pdf/foo_19thNewsletter.pdf\",true,\"/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg/text\"",
          "\"/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf\",true,\"/content/foo/en/gremlins/jcr:content/content2C/textboximg_114671747/text\",\"/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf\",\"/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg_0/text\""
        ]
      }
    ],
    "identifier": 56132077
  },
  {
    "context": [
      "I would like to escape the pipe character \"|\" in my output so that I can use it as a separator. Not sure how to escape it, though. Any insight?",
      "It does not need to be escaped, only quoted, e.g.\r\n\r\n    1, \"|\", 2\r\n\r\nor\r\n\r\n    \"\\(input)|\\(input)\""
    ],
    "utterance": "Output the pipe character '|' as a separator between values.",
    "expressions": [
      "1, \"|\", 2",
      "\"\\(input)|\\(input)\""
    ],
    "identifier": 56415133
  },
  {
    "context": [
      "I have the following JSON:",
      "\"contexts\": {\n        \"context1\": {\n            \"mydata\": \"value1\"\n        },\n        \"context2\": {\n            \"mydata\": \"value2\"\n        }\n    },\n    \"current_context\": \"context2\"",
      "I'd like to use `jq` to output the value of `mydata` for the context indicated by `current_context`. The above would output `value2`. If I change the JSON to have `\"current_context\": \"context1\"`, I'd get `value1`.",
      "Is there a way to do this with a single invocation of jq?",
      "Like this:\n\n    jq -r '.contexts[.current_context].mydata' file.json",
      "You could also use a variable:\n\n    jq -r '.current_context as $cc|.contexts[$cc].mydata' file.json"
    ],
    "utterance": "Select the value of the 'mydata' property from the context whose name matches the value of the 'current_context' property",
    "expressions": [
      ".contexts[.current_context].mydata",
      ".current_context as $cc|.contexts[$cc].mydata"
    ],
    "data": [
      {
        "input": {
          "contexts": {
            "context1": {
              "mydata": "value1"
            },
            "context2": {
              "mydata": "value2"
            }
          },
          "current_context": "context2"
        },
        "output": "value2"
      },
      {
        "input": {
          "contexts": {
            "context1": {
              "mydata": "value1"
            },
            "context2": {
              "mydata": "value2"
            }
          },
          "current_context": "context1"
        },
        "output": "value1"
      }
    ],
    "identifier": 56414157
  },
  {
    "context": [
      "Attempting to print data formatted in a specific way, but the conditional doesn't work correctly.",
      "I've written a simple test:",
      "jq -r \". | if (.[].nickname | length) >15 then \\\"\\(.[].nickname)\\t\\(.[].fingerprint)\\\" else \\\"no\\\" end\" running.json",
      "Where running.json is this sample json:",
      "[{\"nickname\": \"FiverInstitute11\",\"fingerprint\": \"0011BD2J8D3J45D984EC4159C88FC066E5E3300E\"}, {\"nickname\": \"Something13\",\"fingerprint\": \"0077BCBA7244DB3E6O2AD274H886170066684887\"}, {\"nickname\": \"je8gvke8s2ff063CMbc\",\"fingerprint\": \"00B87ECU71DBF56805NE8469BAF3924A13AD7\"}, {\"nickname\": \"test931\",\"fingerprint\": \"00DC112F7D469AD7E0E4B378D050490811BB20E5\"}]",
      "The output never prints \"no\" even in the case that the conditional is false. Anyone know how this is fixed?",
      "Every occurrence of .[] expands the array, so when you write something like `if .[] ...` it is like a `for` loop.",
      "So your jq program effectively has a for loop within a for loop within a for loop.",
      "Perhaps you meant:",
      ".[] | if (.nickname | length) > 15 then \"\\(.nickname)\\t\\(.fingerprint)\" else \"no\" end"
    ],
    "utterance": "For each element in the array, print \"<nickname>\\t<fingerprint>\" if nickname length is greater than 15; otherwise, print \"no\".",
    "expressions": [
      ".[] | if (.nickname | length) > 15 then \"\\(.nickname)\\t\\(.fingerprint)\" else \"no\" end"
    ],
    "data": [
      {
        "input": [
          {
            "nickname": "FiverInstitute11",
            "fingerprint": "0011BD2J8D3J45D984EC4159C88FC066E5E3300E"
          },
          {
            "nickname": "Something13",
            "fingerprint": "0077BCBA7244DB3E6O2AD274H886170066684887"
          },
          {
            "nickname": "je8gvke8s2ff063CMbc",
            "fingerprint": "00B87ECU71DBF56805NE8469BAF3924A13AD7"
          },
          {
            "nickname": "test931",
            "fingerprint": "00DC112F7D469AD7E0E4B378D050490811BB20E5"
          }
        ],
        "output": [
          "FiverInstitute11\t0011BD2J8D3J45D984EC4159C88FC066E5E3300E",
          "no",
          "je8gvke8s2ff063CMbc\t00B87ECU71DBF56805NE8469BAF3924A13AD7",
          "no"
        ]
      }
    ],
    "identifier": 56412209
  },
  {
    "context": [
      "There are multiple occurrence of the `id` value but I want the value of the first `ID` to be stored in the `id` variable which is `\"id\": 1234332`",
      "Use [tag:jq] for parsing JSON values, sed is a line-oriented tool and can't parse JSON syntax-wise.",
      "E.g:",
      "id=$(curl -H 'Authorization:token xxxxxxxxxxxxxxxxxxxxxx' -H 'Content-Type: application/json' 'https://api.github.com/repos/octocat/Hello-World/releases/tags/v1.0.0' |",
      "  jq -r '.id')",
      "echo \"$id\""
    ],
    "utterance": "Extract the top-level id field with value 1234332 from the API response containing multiple id occurrences.",
    "expressions": [
      ".id",
      ".[\"id\"]"
    ],
    "data": [
      {
        "input": {
          "url": "https://api.github.com/repos/octocat/Hello-World/releases/1",
          "html_url": "https://github.com/octocat/Hello-World/releases/v1.0.0",
          "assets_url": "https://api.github.com/repos/octocat/Hello-World/releases/1/assets",
          "upload_url": "https://uploads.github.com/repos/octocat/Hello-World/releases/1/assets{?name,label}",
          "tarball_url": "https://api.github.com/repos/octocat/Hello-World/tarball/v1.0.0",
          "zipball_url": "https://api.github.com/repos/octocat/Hello-World/zipball/v1.0.0",
          "id": 1234332,
          "node_id": "MDc6UmVsZWFzZTE=",
          "tag_name": "v1.0.0",
          "target_commitish": "master",
          "name": "v1.0.0",
          "body": "Description of the release",
          "draft": false,
          "prerelease": false,
          "created_at": "2013-02-27T19:35:32Z",
          "published_at": "2013-02-27T19:35:32Z",
          "author": {
            "login": "octocat",
            "id": 1353322,
            "node_id": "MDQ6VXNlcjE=",
            "avatar_url": "https://github.com/images/error/octocat_happy.gif",
            "gravatar_id": "",
            "url": "https://api.github.com/users/octocat",
            "html_url": "https://github.com/octocat",
            "followers_url": "https://api.github.com/users/octocat/followers",
            "following_url": "https://api.github.com/users/octocat/following{/other_user}",
            "gists_url": "https://api.github.com/users/octocat/gists{/gist_id}",
            "starred_url": "https://api.github.com/users/octocat/starred{/owner}{/repo}",
            "subscriptions_url": "https://api.github.com/users/octocat/subscriptions",
            "organizations_url": "https://api.github.com/users/octocat/orgs",
            "repos_url": "https://api.github.com/users/octocat/repos",
            "events_url": "https://api.github.com/users/octocat/events{/privacy}",
            "received_events_url": "https://api.github.com/users/octocat/received_events",
            "type": "User",
            "site_admin": false
          },
          "assets": [
            {
              "url": "https://api.github.com/repos/octocat/Hello-World/releases/assets/1",
              "browser_download_url": "https://github.com/octocat/Hello-World/releases/download/v1.0.0/example.zip",
              "id": 56432211,
              "node_id": "MDEyOlJlbGVhc2VBc3NldDE=",
              "name": "example.zip",
              "label": "short description",
              "state": "uploaded",
              "content_type": "application/zip",
              "size": 1024,
              "download_count": 42,
              "created_at": "2013-02-27T19:35:32Z",
              "updated_at": "2013-02-27T19:35:32Z",
              "uploader": {
                "login": "octocat",
                "id": 5663322,
                "node_id": "MDQ6VXNlcjE=",
                "avatar_url": "https://github.com/images/error/octocat_happy.gif",
                "gravatar_id": "",
                "url": "https://api.github.com/users/octocat",
                "html_url": "https://github.com/octocat",
                "followers_url": "https://api.github.com/users/octocat/followers",
                "following_url": "https://api.github.com/users/octocat/following{/other_user}",
                "gists_url": "https://api.github.com/users/octocat/gists{/gist_id}",
                "starred_url": "https://api.github.com/users/octocat/starred{/owner}{/repo}",
                "subscriptions_url": "https://api.github.com/users/octocat/subscriptions",
                "organizations_url": "https://api.github.com/users/octocat/orgs",
                "repos_url": "https://api.github.com/users/octocat/repos",
                "events_url": "https://api.github.com/users/octocat/events{/privacy}",
                "received_events_url": "https://api.github.com/users/octocat/received_events",
                "type": "User",
                "site_admin": false
              }
            }
          ]
        },
        "output": 1234332
      }
    ],
    "identifier": 56206151
  },
  {
    "context": [
      "jq '._meta[][].ansible_ssh_pass | sub(\" .*\" ; \"\")'",
      "This jq-call does what I need:",
      "jq '. ._meta.hostvars[].ansible_ssh_pass |= sub(\" .*\";\"\" )'",
      "Output should be something like this:",
      "{\"_meta\": {",
      "    \"hostvars\": {",
      "      \"10.1.1.3\": {",
      "        \"hostname\": \"core-gw1\",",
      "        \"ansible_user\": \"\",",
      "        \"ansible_ssh_pass\": \"test123\",",
      "        \"configsicherung\": \"true\",",
      "        \"os\": \"ios\",",
      "        \"managementpaket\": \"\"",
      "      }",
      "    }",
      "}}"
    ],
    "utterance": "Remove everything after the first space in the value of every ansible_ssh_pass field within all hostvars, preserving the overall structure.",
    "expressions": [
      "._meta.hostvars[].ansible_ssh_pass |= sub(\" .*\";\"\")"
    ],
    "data": [
      {
        "input": {
          "_meta": {
            "hostvars": {
              "10.1.1.3": {
                "hostname": "core-gw1",
                "ansible_user": "",
                "ansible_ssh_pass": "test123 / ena: test2",
                "configsicherung": "true",
                "os": "ios",
                "managementpaket": ""
              }
            }
          }
        },
        "output": {
          "_meta": {
            "hostvars": {
              "10.1.1.3": {
                "hostname": "core-gw1",
                "ansible_user": "",
                "ansible_ssh_pass": "test123",
                "configsicherung": "true",
                "os": "ios",
                "managementpaket": ""
              }
            }
          }
        }
      }
    ],
    "identifier": 56442259
  },
  {
    "context": [
      "why is `first(select(.updated_at==\"2019-06-03T16:36:53.194Z\"))` returning more than 1 result when input is",
      "Because, `first`'s input is a stream of objects and thus it is run once for each one. To run it once for entire stream specify `-n/--null-input` flag on the command line and access inputs using the `inputs` function. This way `first`'s input will be `null` and its argument will be a stream of objects `select`ed from `inputs`, so it will be able to yield only the first one.",
      "$ jq -n 'first(inputs | select(.updated_at == \"2019-06-03T16:36:53.194Z\"))' file"
    ],
    "utterance": "Return only the first object where updated_at equals 2019-06-03T16:36:53.194Z from the input stream.",
    "expressions": [
      "first(inputs | select(.updated_at == \"2019-06-03T16:36:53.194Z\"))"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "a",
            "updated_at": "2019-06-03T16:36:53.194Z"
          },
          {
            "_id": "b",
            "updated_at": "2019-06-03T19:27:15.192Z"
          },
          {
            "_id": "c",
            "updated_at": "2019-06-03T20:02:11.538Z"
          },
          {
            "_id": "d",
            "updated_at": "2019-06-03T21:12:05.764Z"
          },
          {
            "_id": "e",
            "updated_at": "2019-06-04T07:55:04.251Z"
          },
          {
            "_id": "f",
            "updated_at": "2019-06-03T22:21:37.276Z"
          },
          {
            "_id": "g",
            "updated_at": "2019-06-03T20:57:42.296Z"
          },
          {
            "_id": "h",
            "updated_at": "2019-06-03T18:56:07.687Z"
          },
          {
            "_id": "i",
            "updated_at": "2019-06-04T09:28:08.276Z"
          },
          {
            "_id": "j",
            "updated_at": "2019-06-04T08:54:05.048Z"
          },
          {
            "_id": "k",
            "updated_at": "2019-06-03T16:36:53.194Z"
          },
          {
            "_id": "l",
            "updated_at": "2019-06-03T16:36:53.194Z"
          }
        ],
        "output": {
          "_id": "a",
          "updated_at": "2019-06-03T16:36:53.194Z"
        }
      }
    ],
    "identifier": 56442850
  },
  {
    "context": [
      "I would like to add 4 columns to the left to show for each `Abc` value the corresponding page, row and column. Additionally if possible as first column add a counter from 1 to number of \"Abc\" elements.",
      "[\"counter\", \"page\", \"row\", \"column\", \"Abc\"],\n(foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\n  .page += 1\n  | if ($page | (has(\"image\") and (.image|has(\"Abc\"))))\n    then\n      .counter +=1\n      | .out = [.counter, .page, null, null, ($page|.image.Abc)]\n    else foreach ($page | .row[]?) as $row (.row=-1;\n      .row += 1\n      | foreach ($row | .column[]) as $column (.column=-1;\n          .column +=1\n          | foreach ($column | .text | objects) as $x (.;\n              .counter += 1\n              | .out = [.counter, .page, .row, .column, $x[\"Abc\"]]\n              ; . )\n           ; . )\n      ; . )\n  \tend\n    ; .out )\n)\n| @tsv",
      "# add a sequential id, starting at 1\ndef tsvRows(s):\n  foreach s as $s (0; .+1; [.] + $s)\n  | @tsv;\n\n([\"counter\", \"page\", \"row\", \"column\", \"Abc\"] | @tsv),\ntsvRows(paths as $p\n  | select($p[-1] == \"Abc\")\n  | getpath($p) as $v\n  | $p\n  | .[2] as $page\n  | (if .[3] == \"row\" then .[4] else null end) as $row\n  | (if .[5] == \"column\" then .[6] else null end) as $column\n  | [$page, $row, $column, $v] )"
    ],
    "utterance": "Produce a table where each row lists a running counter, the page, row, and column indices, and the Abc value for each Abc entry in the nested data structure.",
    "expressions": [
      "[\"counter\", \"page\", \"row\", \"column\", \"Abc\"],\n(foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\n  .page += 1\n  | if ($page | (has(\"image\") and (.image|has(\"Abc\"))))\n    then\n      .counter +=1\n      | .out = [.counter, .page, null, null, ($page|.image.Abc)]\n    else foreach ($page | .row[]?) as $row (.row=-1;\n      .row += 1\n      | foreach ($row | .column[]) as $column (.column=-1;\n          .column +=1\n          | foreach ($column | .text | objects) as $x (.;\n              .counter += 1\n              | .out = [.counter, .page, .row, .column, $x[\"Abc\"]]\n              ; . )\n           ; . )\n      ; . )\n  \tend\n    ; .out )\n)\n| @tsv",
      "# add a sequential id, starting at 1\ndef tsvRows(s):\n  foreach s as $s (0; .+1; [.] + $s)\n  | @tsv;\n\n([\"counter\", \"page\", \"row\", \"column\", \"Abc\"] | @tsv),\ntsvRows(paths as $p\n  | select($p[-1] == \"Abc\")\n  | getpath($p) as $v\n  | $p\n  | .[2] as $page\n  | (if .[3] == \"row\" then .[4] else null end) as $row\n  | (if .[5] == \"column\" then .[6] else null end) as $column\n  | [$page, $row, $column, $v] )"
    ],
    "data": [
      {
        "input": {
          "document": {
            "page": [
              {
                "@index": "0",
                "image": {
                  "Abc": "4"
                }
              },
              {
                "@index": "1",
                "row": [
                  {
                    "column": [
                      {
                        "text": {
                          "Abc": "2"
                        }
                      }
                    ]
                  },
                  {
                    "column": [
                      {
                        "text": {
                          "Abc": "1"
                        }
                      },
                      {
                        "text": {
                          "Abc": "9"
                        }
                      }
                    ]
                  },
                  {
                    "column": [
                      {
                        "text": {
                          "Abc": "3"
                        }
                      }
                    ]
                  }
                ]
              },
              {
                "@index": "2",
                "row": [
                  {
                    "column": [
                      {
                        "text": {
                          "Abc": "2"
                        }
                      }
                    ]
                  },
                  {
                    "column": [
                      {
                        "text": {
                          "Abc": "4"
                        }
                      },
                      {
                        "text": {
                          "Abc": "9"
                        }
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": "counter\tpage\trow\tcolumn\tAbc\n1\t0\t\t\t4\n2\t1\t0\t0\t2\n3\t1\t1\t0\t1\n4\t1\t1\t1\t9\n5\t1\t2\t0\t3\n6\t2\t0\t0\t2\n7\t2\t1\t0\t4\n8\t2\t1\t1\t9"
      }
    ],
    "identifier": 56386521
  },
  {
    "context": [
      "Is there a stream version were as soon as a new element appears it would flush it to stdout?",
      "You could use it with the -n command line option like so:",
      "unique(inputs)"
    ],
    "utterance": "Output each distinct object from the input as soon as it appears, emitting only new, unique elements immediately.",
    "expressions": [
      "def unique(stream): foreach stream as $s ({};\n     ($s|type) as $t\n     | ($s|tostring) as $y\n     | if .[$t][$y] then .emit = false\n       else .emit = true | (.item = $s) | (.[$t][$y] = true)\n       end;\n     if .emit then .item else empty end ); unique(inputs)"
    ],
    "identifier": 56446693
  },
  {
    "context": [
      "How to extract two fields from a JSON file using jq?",
      "I would like the output to be this way:\r\naaaa-cn001.me.com 3.10.0-957.12.1.el7.x86_64\r\naaaa-cn002.me.com 3.10.0-957.10.1.el7.x86_64\r\naaaa-cn003.me.com 3.10.0-957.10.1.el7.x86_64\r\naaaa-cn004.me.com 3.10.0-957.12.1.el7.x86_64",
      "Looks like you want the following :\r\n\r\n    jq --raw-output '.items[] | .node + \" \" + .result.stdout' out.json"
    ],
    "utterance": "Extract the node name and the result's stdout for each item, separated by a space, listing all items.",
    "expressions": [
      ".items[] | .node + \" \" + .result.stdout",
      "--raw-output '.items[] | .node + \" \" + .result.stdout'"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "node": "aaaa-cn001.me.com",
              "status": "success",
              "result": {
                "stdout": "3.10.0-957.12.1.el7.x86_64\n",
                "stderr": "",
                "exit_code": 0
              }
            },
            {
              "node": "aaaa-cn002.me.com",
              "status": "success",
              "result": {
                "stdout": "3.10.0-957.10.1.el7.x86_64\n",
                "stderr": "",
                "exit_code": 0
              }
            },
            {
              "node": "aaaa-cn003.me.com",
              "status": "success",
              "result": {
                "stdout": "3.10.0-957.10.1.el7.x86_64\n",
                "stderr": "",
                "exit_code": 0
              }
            },
            {
              "node": "aaaa-cn004.me.com",
              "status": "success",
              "result": {
                "stdout": "3.10.0-957.12.1.el7.x86_64\n",
                "stderr": "",
                "exit_code": 0
              }
            }
          ]
        },
        "output": "aaaa-cn001.me.com 3.10.0-957.12.1.el7.x86_64\naaaa-cn002.me.com 3.10.0-957.10.1.el7.x86_64\naaaa-cn003.me.com 3.10.0-957.10.1.el7.x86_64\naaaa-cn004.me.com 3.10.0-957.12.1.el7.x86_64\n"
      }
    ],
    "identifier": 56444091
  },
  {
    "context": [
      "I want `nextToken`'s value and `jobName` in one jq command.",
      "jq '.nextToken, .jobSummaryList[].jobName' file"
    ],
    "utterance": "Extract the value of nextToken and each jobName in a single command.",
    "expressions": [
      ".nextToken, .jobSummaryList[].jobName"
    ],
    "data": [
      {
        "input": {
          "nextToken": "9i2x1mbCpfo5hQ",
          "jobSummaryList": [
            {
              "jobName": "012210",
              "jobId": "0196f81cae73"
            }
          ]
        },
        "output": [
          "9i2x1mbCpfo5hQ",
          "012210"
        ]
      }
    ],
    "identifier": 56457558
  },
  {
    "context": [
      "I want to get the ip only in json result like '34.10.12.40'",
      "http -b ifconfig.co/json | jq '.ip'",
      "Sample output:",
      "\"92.121.64.197\"",
      "Above command will override the default `entrypoint` with `/bin/sh`, then you can use `jq` to parse output of `httpie` in pipeline."
    ],
    "utterance": "Extract the value of the 'ip' field from the API response containing fields like 'ip', 'country', and others.",
    "expressions": [
      ".ip"
    ],
    "data": [
      {
        "input": {
          "country": "United States",
          "country_eu": false,
          "country_iso": "US",
          "hostname": "lqwtx.com",
          "ip": "34.10.12.40",
          "ip_decimal": 39585,
          "latitude": 35,
          "longitude": 105
        },
        "output": "34.10.12.40"
      }
    ],
    "identifier": 56452639
  },
  {
    "context": [
      "I want to have all B element with the same name as A element. So in this case the result would be `['text',10,'text2',40]`.",
      "You better do something like this:\n```\n( .B | map({(.name): .power}) | add ) as $b\n| .A | map(.AT | [., $b[.]]) | add\n```",
      "If your input is too big using `reduce` you can get better performance:\n```\n( reduce .B[] as $b ({}; . + ($b | {(.name): .power})) ) as $b\n| reduce .A[].AT as $a ([]; . + [$a, $b[$a]])\n```"
    ],
    "utterance": "Get an array containing the name and power for each object in B whose name matches any AT value in A.",
    "expressions": [
      "( .B | map({(.name): .power}) | add ) as $b | .A | map(.AT | [., $b[.]]) | add",
      "( reduce .B[] as $b ({}; . + ($b | {(.name): .power})) ) as $b | reduce .A[].AT as $a ([]; . + [$a, $b[$a]])"
    ],
    "data": [
      {
        "input": {
          "A": [
            {
              "AT": "text"
            },
            {
              "AT": "text2"
            }
          ],
          "B": [
            {
              "name": "text",
              "power": 10
            },
            {
              "name": "text1",
              "power": 20
            },
            {
              "name": "text2",
              "power": 40
            }
          ]
        },
        "output": [
          "text",
          10,
          "text2",
          40
        ]
      }
    ],
    "identifier": 56441926
  },
  {
    "context": [
      "how to express and check for a minimum version of a module number? For instance:",
      "module { \n   name: \"math\",\n   version: \"0.1.0\",\n   dependencies: {\"util\": \"1.0.0\"} };",
      "jq -n -L . '\n  include \"dependencies\";\n  include \"math\";\n\n  \"math\" | dependencies,\n  (123|digitroot) '"
    ],
    "utterance": "Specify and enforce that the 'math' module requires at least version 1.0.0 of the 'util' module as a dependency.",
    "expressions": [
      "\"math\" | dependencies"
    ],
    "identifier": 56467959
  },
  {
    "context": [
      "Now I want to get another new json banner from the source json file above (extract_3month_fromshodan.json) by filtering  the parameter i.e. ip_str=\"126.100.105.198\" and timestamp=\"2018-08-11T04:56:17.312039\".",
      "I should get extracted/filtered json banner including all relevant fields w.r.t 290 IPs and timestamp (kept in csv or txt file) from the main json banner (containing more than 500 IPs).",
      "jq '. | select (.timestamp=\"2018-08-11T04:56:17.312039\") | select(.ip_str==\"126.100.105.198\")' extract_3month_fromshodan.json > all.json",
      "while read -r ts ip\n    do\n      jq --arg ts \"$ts\" --arg ip \"$ip\" '\n        select(.timestamp==$ts and .ip_str==$ip)\n      ' extract_3month_fromshodan.json\n    done < inputfile.txt"
    ],
    "utterance": "Select all objects where ip_str equals \"126.100.105.198\" and timestamp equals \"2018-08-11T04:56:17.312039\".",
    "expressions": [
      ". | select(.timestamp==\"2018-08-11T04:56:17.312039\" and .ip_str==\"126.100.105.198\")",
      "--arg ts \"$ts\" --arg ip \"$ip\" '. | select(.timestamp==$ts and .ip_str==$ip)'"
    ],
    "data": [
      {
        "input": [
          {
            "asn": "AS17676",
            "hash": -619087650,
            "ip": 2120548325,
            "isp": "Softbank BB",
            "transport": "udp",
            "data": "HTTP/1.1 200 OK\r\nCache-Control: max-age=120\r\nST:  upnp:rootdevice\r\nUSN: uuid:12342409-1234-1234-5678-ee1234cc5678::upnp:rootdevice\r\nEXT:\r\nServer: miniupnpd/1.0 UPnP/1.0\r\nLocation: http://192.168.2.1:52869/picsdesc.xml\r\n\r\n",
            "port": 1900,
            "hostnames": [
              "softbank126100255229.bbtec.net"
            ],
            "location": {
              "city": "Toyota",
              "region_code": "01",
              "area_code": null,
              "longitude": 137.14999999999998,
              "country_code3": "JPN",
              "latitude": 35.08330000000001,
              "postal_code": "457-0844",
              "dma_code": null,
              "country_code": "JP",
              "country_name": "Japan"
            },
            "timestamp": "2018-09-12T15:42:34.012436",
            "domains": [
              "bbtec.net"
            ],
            "org": "XXXXXX BB",
            "os": null,
            "_shodan": {
              "crawler": "d264629436af1b777b3b513ca6ed1404d7395d80",
              "options": {},
              "module": "upnp",
              "id": null
            },
            "opts": {},
            "ip_str": "126.100.255.229"
          },
          {
            "asn": "AS17676",
            "hash": 1371060454,
            "ip": 2120509894,
            "isp": "Softbank BB",
            "transport": "udp",
            "data": "HTTP/1.1 200 OK\r\nCache-Control: max-age=1800\r\nST: upnp:rootdevice\r\nUSN: uuid:63041253-1019-2006-1228-00018efed688::upnp:rootdevice\r\nEXT:\r\nServer: OS 1.0 UPnP/1.0 Realtek/V1.3\r\nLocation: http://192.168.2.1:52881/simplecfg.xml\r\n\r\n",
            "port": 1900,
            "hostnames": [
              "softbank126100105198.bbtec.net"
            ],
            "location": {
              "city": "Yamashitacho",
              "region_code": "18",
              "area_code": null,
              "longitude": 130.55,
              "country_code3": "JPN",
              "latitude": 31.58330000000001,
              "postal_code": "892-0816",
              "dma_code": null,
              "country_code": "JP",
              "country_name": "Japan"
            },
            "timestamp": "2018-08-11T04:56:17.312039",
            "domains": [
              "bbtec.net"
            ],
            "org": "Softbank BB",
            "os": null,
            "_shodan": {
              "crawler": "6ff540e4d43ec69d8de2a7b60e1de2d9ddb406dc",
              "options": {},
              "module": "upnp",
              "id": null
            },
            "opts": {},
            "ip_str": "126.100.105.198"
          }
        ],
        "output": {
          "asn": "AS17676",
          "hash": 1371060454,
          "ip": 2120509894,
          "isp": "Softbank BB",
          "transport": "udp",
          "data": "HTTP/1.1 200 OK\r\nCache-Control: max-age=1800\r\nST: upnp:rootdevice\r\nUSN: uuid:63041253-1019-2006-1228-00018efed688::upnp:rootdevice\r\nEXT:\r\nServer: OS 1.0 UPnP/1.0 Realtek/V1.3\r\nLocation: http://192.168.2.1:52881/simplecfg.xml\r\n\r\n",
          "port": 1900,
          "hostnames": [
            "softbank126100105198.bbtec.net"
          ],
          "location": {
            "city": "Yamashitacho",
            "region_code": "18",
            "area_code": null,
            "longitude": 130.55,
            "country_code3": "JPN",
            "latitude": 31.58330000000001,
            "postal_code": "892-0816",
            "dma_code": null,
            "country_code": "JP",
            "country_name": "Japan"
          },
          "timestamp": "2018-08-11T04:56:17.312039",
          "domains": [
            "bbtec.net"
          ],
          "org": "Softbank BB",
          "os": null,
          "_shodan": {
            "crawler": "6ff540e4d43ec69d8de2a7b60e1de2d9ddb406dc",
            "options": {},
            "module": "upnp",
            "id": null
          },
          "opts": {},
          "ip_str": "126.100.105.198"
        }
      }
    ],
    "identifier": 56205157
  },
  {
    "context": [
      "I'm trying to get the last X versions sorted by version (they are sorted by release date currently).",
      "It looks like jq can't sort a stream of objects directly, sort_by only works on arrays, and I couldn't find a way to collect a stream into an array that doesn't involve piping the output of jq -c to jq -s.",
      "In `jq` you can always contain the results to an array using the `[..]` that put the results to an array for the subsequent functions to operate on. Your given requirement could be simply done as",
      "jq '[.[] | select(.platform | contains(\"Unix\"))] | sort_by(.version) | limit(5;.[])'"
    ],
    "utterance": "Filter objects where the platform contains 'Unix', sort them by version, and output the last 5 versions.",
    "expressions": [
      "[.[] | select(.platform | contains(\"Unix\"))] | sort_by(.version) | limit(5;.[])",
      "[[.[] | select(.platform | contains(\"Unix\"))] | sort_by(.version) | limit(5;.[])] | reverse"
    ],
    "identifier": 56475052
  },
  {
    "context": [
      "The output I'm trying to get is:\r\n\r\n    #text @x     @y\r\n    Text1 121.10 83.42\r\n    Text2 121.10 124.82\r\n    Text3 65.10  69.62\r\n    Text4 85.10  83.42\r\n    Text5 85.10  97.22\r\n\r\nHow can achieve this?",
      "If possible, how to add the follwing 3 columns (counter, page and row) to know the corresponding page and row for each line?",
      "The expected output would be like this:\r\n\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| counter | page | row | #text             | @data | @fontName | @fontSize | @format | @height | @type         | @width | @x     | @y     |",
      "The following solution uses a \"drill-down\" approach.  The following will be a bit difficult to understand unless you understand `foreach`, so let me just mention that the approach essentially uses a state variable {counter, page, row} to keep track of the three counters.\r\n\r\n    [\"counter\", \"page\", \"row\", \"#text\", \"@data\", \"@fontName\", \"@fontSize\", \"@format\", \"@height\", \"@type\", \"@width\", \"@x\", \"@y\"], \r\n    (foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\r\n      .page += 1\r\n      | foreach ($page | .row[]?) as $row (.row=-1;\r\n        .row += 1\r\n        | foreach ($row | (.column | (if type == \"array\" then .[] else . end )) | .text | objects) as $x (.;\r\n          .counter += 1\r\n          | .out = [.counter, .page, .row, $x[\"#text\", \"@data\", \"@fontName\", \"@fontSize\", \"@format\", \"@height\", \"@type\", \"@width\", \"@x\", \"@y\"]]\r\n          ; . )\r\n          ; . )\r\n          ; .out )\r\n    )\r\n    | @tsv"
    ],
    "utterance": "Extract all text blocks along with data fields and add columns for counter, page, and row to produce a table with headers: counter, page, row, #text, @data, @fontName, @fontSize, @format, @height, @type, @width, @x, @y.",
    "expressions": [
      "[\"counter\", \"page\", \"row\", \"#text\", \"@data\", \"@fontName\", \"@fontSize\", \"@format\", \"@height\", \"@type\", \"@width\", \"@x\", \"@y\"],\n(foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\n  .page += 1\n  | foreach ($page | .row[]?) as $row (.row=-1;\n    .row += 1\n    | foreach ($row | (.column | (if type == \"array\" then .[] else . end )) | .text | objects) as $x (.;\n      .counter += 1\n      | .out = [.counter, .page, .row, $x[\"#text\", \"@data\", \"@fontName\", \"@fontSize\", \"@format\", \"@height\", \"@type\", \"@width\", \"@x\", \"@y\"]]\n      ; . )\n      ; . )\n      ; .out )\n)\n| @tsv"
    ],
    "identifier": 56370993
  },
  {
    "context": [
      "I need to iterate through this JSON array and record the num-of-connections value if it is greater than 0, then, if it is greater than 0 record the owner and their last-disconnection-time and store them to be output to the console once the script is done.",
      "user $owner has $num-of-connections open connections and last disconnected at $last-disconnection-time .",
      "jq -r '.[] | select(.\"num-of-connections\" > 0) | \"User \\(.owner) has \\(.\"num-of-connections\") open connections and last disconnected at \\(.\"last-disconnection-time\").\"' test.json",
      "jq -r '.[] | select(.\"num-of-connections\">0) | \"\\(.owner) \\(.\"num-of-connections\") \\(.\"last-disconnection-time\")\"' input.json",
      "jq '.[] | select(.\"num-of-connections\">0) | {\"owner\": .\"owner\", \"num-of-connections\": .\"num-of-connections\", \"last-disconnection-time\": .\"last-disconnection-time\"}' input.json"
    ],
    "utterance": "For each array element where num-of-connections is greater than 0, output the owner, num-of-connections, and last-disconnection-time.",
    "expressions": [
      ".[] | select(.\"num-of-connections\" > 0) | {\"owner\": .\"owner\", \"num-of-connections\": .\"num-of-connections\", \"last-disconnection-time\": .\"last-disconnection-time\"}",
      ".[] | select(.\"num-of-connections\" > 0) | \"User \\(.owner) has \\(.\"num-of-connections\") open connections and last disconnected at \\(.\"last-disconnection-time\").\"",
      ".[] | select(.\"num-of-connections\" > 0) | \"\\(.owner) \\(.\"num-of-connections\") \\(.\"last-disconnection-time\")\""
    ],
    "data": [
      {
        "input": [
          {
            "id": "123456",
            "owner": "johndoe",
            "x11-display": ":9",
            "x11-authority": "/run/user/1112/dcv/123456.xauth",
            "num-of-connections": 1,
            "creation-time": "2019-05-28T14:42:24.027240Z",
            "last-disconnection-time": "2019-05-30T21:47:36.682935Z"
          },
          {
            "id": "12345",
            "owner": "johnsmith",
            "x11-display": ":5",
            "x11-authority": "/run/user/user/dcv/12345.xauth",
            "num-of-connections": 0,
            "creation-time": "2019-05-14T14:12:14.989287Z",
            "last-disconnection-time": "2019-05-31T18:58:42.851223Z"
          }
        ],
        "output": [
          "User johndoe has 1 open connections and last disconnected at 2019-05-30T21:47:36.682935Z."
        ]
      }
    ],
    "identifier": 56446282
  },
  {
    "context": [
      "I try to wait with `await` but I don't know where I can put this keyword. So here's my code:",
      "The whole point of asynchronous APIs is that you can't write",
      "That said, `async` / `await` let you convert asynchronous code into synchronous code (or at least something that looks synchronous). However, this trick only works \"on the inside\": The external interface is still asynchronous, you can just write more normal looking code internally.",
      "For example:\n\n    // await is only available inside async functions, so let's define one:\n    (async function () {\n    \n        // magic happens here:\n        let data = await jq.run(filter, jsonPath);\n    \n        fs.appendFile('./jqTest.txt', data + \"\\r\\n\", (err) => {\n            if (err) throw err;\n            console.log(\"complete!\")\n        });\n    \n    })();  // ... and invoke it immediately"
    ],
    "utterance": "Retrieve the values at .root[].A[].AT from a file and append the result to jqTest.txt, ensuring the data is available before writing the file.",
    "expressions": [
      "(async function () {\n  let data = await jq.run(filter, jsonPath);\n  fs.appendFile('./jqTest.txt', data + \"\\r\\n\", (err) => {\n    if (err) throw err;\n    console.log(\"complete!\");\n  });\n})();"
    ],
    "data": [
      {
        "input": "Contents of simple.json file complying with .root[].A[].AT structure"
      }
    ],
    "identifier": 56468234
  },
  {
    "context": [
      "Desired output is:\r\n\r\n        {\r\n            \"Category\": [\r\n            \"Data\",\r\n            \"EMR\"\r\n            ],\r\n           \"Environment\": \"NonProd\",\r\n           \"Severity\": \"Critical\"\r\n        }",
      "Output is:\r\n\r\n    {\r\n      \"Environment\": \"NonProd\",\r\n      \"Severity\": \"Critical\",\r\n      \"Category\": [\r\n        {\r\n          \"S\": \"Data\"\r\n        },\r\n        {\r\n          \"S\": \"EMR\"\r\n        }\r\n      ]\r\n    }\r\n\r\nAs you see it's close, but it's not processing the Category list.",
      "You can use the following :\r\n\r\n    .[] | { Environment: .Environment.S, Severity: .Severity.S, Category: (.Category.L | map(.S)) }\r\n\r\nOutput :\r\n\r\n    {\r\n      \"Environment\": \"NonProd\",\r\n      \"Severity\": \"Critical\",\r\n      \"Category\": [\r\n        \"Data\",\r\n        \"EMR\"\r\n      ]\r\n    }"
    ],
    "utterance": "Extract the values of 'Environment' and 'Severity', and convert the list of objects in 'Category.L' with 'S' keys into an array of their string values.",
    "expressions": [
      ".[] | { Environment: .Environment.S, Severity: .Severity.S, Category: (.Category.L | map(.S)) }"
    ],
    "data": [
      {
        "input": [
          {
            "Environment": {
              "S": "NonProd"
            },
            "Severity": {
              "S": "Critical"
            },
            "Category": {
              "L": [
                {
                  "S": "Data"
                },
                {
                  "S": "EMR"
                }
              ]
            }
          }
        ],
        "output": {
          "Environment": "NonProd",
          "Severity": "Critical",
          "Category": [
            "Data",
            "EMR"
          ]
        }
      }
    ],
    "identifier": 56480943
  },
  {
    "context": [
      "I want to combine objects from both files if they have a common key 'id', but to extract only 'name' property from file1.",
      "This is what I want to get:",
      "{\n  \"Fruits\": [\n  {\n    \"name\": \"Apple\",\n    \"weight\": 5,\n    \"id\": 652090\n  },\n  {\n    \"name\": \"Orange\",\n    \"weight\": 7,\n    \"id\": 28748\n  },\n]}\n",
      "jq -n '[inputs.Fruits[]]\n| reduce (group_by(.id)[] | select(length==2)) as $f\n  ([]; . + [$f[1] + ($f[0] | {name})])' file1.json file2.json",
      "jq -n '[inputs.Fruits[]]\n| group_by(.id)\n| map(select(length==2) | add | {name, id, weight})\n' file1.json file2.json",
      ".Fruits |= (. + input.Fruits | [group_by(.id)[] | add | {name,weight,id}])\nfile1.json file2.json"
    ],
    "utterance": "Combine objects from both files where 'id' matches, include only 'name' from the first file and 'weight' and 'id' from the second file in the result.",
    "expressions": [
      "[inputs.Fruits[]] | reduce (group_by(.id)[] | select(length==2)) as $f ([]; . + [$f[1] + ($f[0] | {name})])",
      "[inputs.Fruits[]] | group_by(.id) | map(select(length==2) | add | {name, id, weight})",
      ".Fruits |= (. + input.Fruits | [group_by(.id)[] | add | {name,weight,id}])"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "Fruits": [
              {
                "name": "Apple",
                "something_else": 123,
                "id": 652090
              },
              {
                "name": "Orange",
                "something_else": 456,
                "id": 28748
              }
            ]
          },
          "file2.json": {
            "Fruits": [
              {
                "weight": 5,
                "id": 652090
              },
              {
                "weight": 7,
                "id": 28748
              }
            ]
          }
        },
        "output": {
          "Fruits": [
            {
              "name": "Apple",
              "weight": 5,
              "id": 652090
            },
            {
              "name": "Orange",
              "weight": 7,
              "id": 28748
            }
          ]
        }
      }
    ],
    "identifier": 56475138
  },
  {
    "context": [
      "what I would like to do is return it as\r\n\r\n    {\r\n      \"label\": \"web page check\",\r\n      \"target\": \"https://www.example.com\"\r\n    },\r\n    {\r\n       \"label\": \"web page check\",\r\n      \"target\": \"https://www.example1.com\"\r\n    }",
      ".[].target |= sub(\"(?<=com).*$\"; \"\")",
      "map(.target |= (capture(\"https?(?<s>://[^/]*)\") | \"https\" + .s))",
      "map(.target |= sub( \"https?(?<s>://[^/]*).*\"; \"https\" + .s) )"
    ],
    "utterance": "Change each object's target value to contain only the scheme and domain, with scheme always set to https",
    "expressions": [
      ".[].target |= sub(\"(?<=com).*$\"; \"\")",
      "map(.target |= (capture(\"https?(?<s>://[^/]*)\") | \"https\" + .s))",
      "map(.target |= sub( \"https?(?<s>://[^/]*).*\"; \"https\" + .s) )"
    ],
    "data": [
      {
        "input": [
          {
            "label": "web page check",
            "target": "http://www.example.com/random/page"
          },
          {
            "label": "web page check1 ",
            "target": "http://www.example1.com/random/page"
          }
        ],
        "output": [
          {
            "label": "web page check",
            "target": "https://www.example.com"
          },
          {
            "label": "web page check1 ",
            "target": "https://www.example1.com"
          }
        ]
      }
    ],
    "identifier": 56493988
  },
  {
    "context": [
      "I would like to insert an item into headers (think *'.headers + {\"Cookie\": \"xyz\"}'*) but I would like the output to be the whole JSON.",
      "Using jq '.headers + {\"Cookie\": \"xyz\"}' only prints out the .headers value. What I am looking to get is the whole entire JSON, but with the cookie subkey included.",
      "Use assignment operators:",
      ".headers += { Cookie: \"xyz\" }",
      ".headers.Cookie = \"xyz\""
    ],
    "utterance": "Add a key 'Cookie' with value 'xyz' to headers and output the entire updated object.",
    "expressions": [
      ".headers += { Cookie: \"xyz\" }",
      ".headers.Cookie = \"xyz\""
    ],
    "data": [
      {
        "input": {
          "headers": {
            "Host": "34.213.0.202",
            "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
            "User-Agent": "Mozilla/5.0 (X11; Linux x86_64; rv:67.0) Gecko/20100101 Firefox/67.0",
            "Accept-Language": "en-US,en;q=0.5",
            "Accept-Encoding": "gzip, deflate",
            "DNT": "1",
            "Connection": "keep-alive",
            "Upgrade-Insecure-Requests": "1",
            "Cache-Control": "max-age=0"
          }
        },
        "output": {
          "headers": {
            "Host": "34.213.0.202",
            "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
            "User-Agent": "Mozilla/5.0 (X11; Linux x86_64; rv:67.0) Gecko/20100101 Firefox/67.0",
            "Accept-Language": "en-US,en;q=0.5",
            "Accept-Encoding": "gzip, deflate",
            "DNT": "1",
            "Connection": "keep-alive",
            "Upgrade-Insecure-Requests": "1",
            "Cache-Control": "max-age=0",
            "Cookie": "xyz"
          }
        }
      }
    ],
    "identifier": 56512803
  },
  {
    "context": [
      "but instead of all those fields, I just want some output like:\n\n\n    alex echo '123'\n    alex echo '789'\n",
      "I also want to filter it so I only see my commands, something like:\n\n    cat <file> | jq -r '.user=alex .cmd'",
      "Use `@tsv` to generated tab-separated values as output:\n\n```\njq -r '[.user, .cmd] | @tsv' <yourfile\n```\n\n...emits, given your input file:\n\n```\nalex\techo '123'\njohn\techo '456'\nalex\techo '789'\n```",
      "...though if you're filtering for only your user account, you can just print `cmd` directly, since the user value is known:\n\n```\njq -r 'select(.user == \"alex\") | .cmd' \n```"
    ],
    "utterance": "Print all command fields for objects where the user field is alex.",
    "expressions": [
      "select(.user == \"alex\") | .cmd",
      ". as $o | select($o.user == \"alex\") | $o.cmd"
    ],
    "data": [
      {
        "input": [
          {
            "user": "alex",
            "num": "486",
            "time": "Thu Jun  6 16:26:06 PDT 2019",
            "pwd": "/Users/alex/codes/ores/prompt-command",
            "pid": 11047,
            "exit_code": 0,
            "cmd": "echo '123'"
          },
          {
            "user": "john",
            "num": "487",
            "time": "Thu Jun  6 16:26:24 PDT 2019",
            "pwd": "/Users/alex/codes/ores/prompt-command",
            "pid": 11108,
            "exit_code": 5,
            "cmd": "echo '456'"
          },
          {
            "user": "alex",
            "num": "488",
            "time": "Thu Jun  6 16:26:59 PDT 2019",
            "pwd": "/Users/alex/codes/ores/prompt-command",
            "pid": 11141,
            "exit_code": 5,
            "cmd": "echo '789'"
          }
        ],
        "output": [
          "echo '123'",
          "echo '789'"
        ]
      }
    ],
    "identifier": 56486272
  },
  {
    "context": [
      "walk(if type == \"object\" and has(\"contents\")\n  then (.contents|sort_by(.size)|reverse)\n  else . end)",
      "walk(if type == \"object\" and has(\"contents\")\n  then .contents |= (sort_by(.size)|reverse)\n  else . end)"
    ],
    "utterance": "Sort the array at every object key named 'contents' in reverse order of each element's 'size' property throughout the structure.",
    "expressions": [
      "walk(if type == \"object\" and has(\"contents\") then .contents |= (sort_by(.size)|reverse) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": 0,
          "c": [
            {
              "a": 1,
              "s": 3,
              "c": [
                {
                  "a": 1,
                  "s": 5
                },
                {
                  "a": 2,
                  "s": 6
                }
              ]
            },
            {
              "a": 2,
              "s": 4
            }
          ]
        }
      }
    ],
    "identifier": 56539699
  },
  {
    "context": [
      "This works fine for some values however, few values need grep to be \"${add}use* internal us-east\", can i use asterisk so that  all my values can be printed.",
      "However, since you are using jq in any case, it would probably be better to perform the filtering by extending the jq filter, for example as follows:",
      "jq --arg add \"$add\" '\n  .Subnets[0].Tags\n  | select(test(\"\\($add)use.* internal us-east\"))\n' subnet.txt "
    ],
    "utterance": "Find elements in .Subnets[0].Tags matching a pattern with a variable prefix, 'use' followed by any characters, then ' internal us-east'",
    "expressions": [
      "jq --arg add \"$add\" '.Subnets[0].Tags | select(test(\"\\($add)use.* internal us-east\"))' subnet.txt"
    ],
    "identifier": 56550933
  },
  {
    "context": [
      "I need to ignore the `\"SegmentType\":[\"2\"]` segments and extract `SegmentID`, `SegmentName`, `BeginningDcuID`, `EndingDcuID`, and `SegmentLength` from the type 1 segments where `IsActive` is `true`.",
      "$ jq '.NewDataSet.Table[]\n| select(.SegmentType[0] != \"2\" and .IsActive[0] == \"true\")\n| (.SegmentID, .SegmentName, .BeginningDcuID, .EndingDcuID, .SegmentLength)[0]' file"
    ],
    "utterance": "Select segments where SegmentType is not '2' and IsActive is 'true', and extract SegmentID, SegmentName, BeginningDcuID, EndingDcuID, and SegmentLength.",
    "expressions": [
      ".NewDataSet.Table[] | select(.SegmentType[0] != \"2\" and .IsActive[0] == \"true\") | (.SegmentID, .SegmentName, .BeginningDcuID, .EndingDcuID, .SegmentLength)[0]"
    ],
    "data": [
      {
        "input": {
          "NewDataSet": {
            "Table": [
              {
                "SegmentID": [
                  "2342"
                ],
                "StationID": [
                  "005es00045:_MN_Stn"
                ],
                "SegmentName": [
                  "I-5 NB MP0.45 @ SR-14"
                ],
                "SegmentType": [
                  "2"
                ],
                "SegmentLength": [
                  "1135"
                ],
                "MinimumLanesReporting": [
                  "0.5"
                ],
                "CalculationThreshold": [
                  "30"
                ],
                "CalculationPeriod": [
                  "2"
                ],
                "MinimumSamples": [
                  "3"
                ],
                "SegmentMaximumFilter": [
                  "774"
                ],
                "SegmentMinimumFilter": [
                  "12"
                ],
                "StandardDeviationSamples": [
                  "15"
                ],
                "StandardDeviationMultiplier": [
                  "1.96"
                ],
                "UseStandardDeviationFilter": [
                  "false"
                ],
                "IsActive": [
                  "true"
                ]
              },
              {
                "SegmentID": [
                  "3051"
                ],
                "BeginningDcuID": [
                  "584"
                ],
                "EndDcuID": [
                  "589"
                ],
                "SourceSystem": [
                  "TravelTime"
                ],
                "SegmentName": [
                  "OR212 at SE 242nd Ave to OR212 at SE Foster Rd"
                ],
                "SegmentType": [
                  "1"
                ],
                "SegmentLength": [
                  "100"
                ],
                "CalculationThreshold": [
                  "60"
                ],
                "CalculationPeriod": [
                  "10"
                ],
                "MinimumSamples": [
                  "3"
                ],
                "SegmentMaximumFilter": [
                  "3600"
                ],
                "SegmentMinimumFilter": [
                  "50"
                ],
                "StandardDeviationSamples": [
                  "20"
                ],
                "StandardDeviationMultiplier": [
                  "1.96"
                ],
                "UseStandardDeviationFilter": [
                  "true"
                ],
                "IsActive": [
                  "true"
                ]
              }
            ]
          }
        },
        "output": [
          "3051",
          "OR212 at SE 242nd Ave to OR212 at SE Foster Rd",
          "584",
          null,
          "100"
        ]
      }
    ],
    "identifier": 56512329
  },
  {
    "context": [
      "How can I find recursively first key with given name using jq?",
      "Is there any way how to tell jq to return me first found json object with key name for example in this case \"model\"? So it returns:",
      "To select just the first, use `first`:",
      "first(.. | objects | select(has(\"model\")))",
      "first(..|select(.model?))"
    ],
    "utterance": "Find the first object, at any depth, that contains a key named \"model\".",
    "expressions": [
      "first(.. | objects | select(has(\"model\")))",
      "first(..|select(.model?))"
    ],
    "data": [
      {
        "input": {
          "firstKey": {
            "secondKey": {
              "model": {
                "name": {
                  "foo": "bar"
                }
              }
            }
          }
        },
        "output": {
          "model": {
            "name": {
              "foo": "bar"
            }
          }
        }
      }
    ],
    "identifier": 56563972
  },
  {
    "context": [
      "I have several JSON files in a folder and I want to combine them in a single one following certain order given in `order.json`",
      "This is the file that gives the order I want to get in output **order.json**",
      "And the output file I\u00b4d like to get would be like this **Merged.json**:",
      "The following solution has the advantage of not requiring any shell-specific functionality and only requiring a single invocation of jq.",
      "jq -n --argfile order order.json '\n  INDEX(inputs.document;  .product) as $dict\n  | reduce $order.order[] as $product ([]; . + [$dict[$product]])\n  | {document: .}\n' [A-Z]*.json",
      "If your jq does not have `INDEX/2`, then it might be a good time to upgrade; alternatively, you could simply add (prepend) its def:",
      "Here's a solution that uses order.json to determine which files are to be read by jq:",
      "jq -n '{documents: [inputs.document]}' $(jq -r '.order[] + \".json\"' order.json)"
    ],
    "utterance": "Merge all files in a folder, combining their contents in the order specified by an order file, so the merged data reflects the order given in that file.",
    "expressions": [
      "jq -n --argfile order order.json '\n  INDEX(inputs.document;  .product) as $dict\n  | reduce $order.order[] as $product ([]; . + [$dict[$product]])\n  | {document: .}\n' [A-Z]*.json",
      "jq -n '{documents: [inputs.document]}' $(jq -r '.order[] + \".json\"' order.json)"
    ],
    "data": [
      {
        "input": {
          "Shoes.json": {
            "document": {
              "product": "Shoes",
              "info": [
                {
                  "day": "1",
                  "month": "1",
                  "entry": "Some text about Shoes for day 1 and month 1",
                  "code": "AJKD"
                },
                {
                  "day": "2",
                  "month": "1",
                  "entry": "Some text about Shoes for day 2 and month 1",
                  "code": "KKGIR"
                }
              ]
            }
          },
          "Watches.json": {
            "document": {
              "product": "Watches",
              "info": [
                {
                  "day": "2",
                  "month": "3",
                  "entry": "Some text about Watches for day 2 and month 3",
                  "code": "PEWQ"
                }
              ]
            }
          },
          "Accesories.json": {
            "document": {
              "product": "Accesories",
              "info": [
                {
                  "day": "7",
                  "month": "2",
                  "entry": "Some text about Accesories for day 7 and month 2",
                  "code": "UYAAC"
                }
              ]
            }
          },
          "order.json": {
            "order": {
              "product 1": "Watches",
              "product 2": "Accesories",
              "product 3": "Shoes"
            }
          }
        },
        "output": {
          "document": [
            {
              "product": "Watches",
              "info": [
                {
                  "day": "2",
                  "month": "3",
                  "entry": "Some text about Watches for day 2 and month 3",
                  "code": "PEWQ"
                }
              ]
            },
            {
              "product": "Accesories",
              "info": [
                {
                  "day": "7",
                  "month": "2",
                  "entry": "Some text about Accesories for day 7 and month 2",
                  "code": "UYAAC"
                }
              ]
            },
            {
              "product": "Shoes",
              "info": [
                {
                  "day": "1",
                  "month": "1",
                  "entry": "Some text about Shoes for day 1 and month 1",
                  "code": "AJKD"
                },
                {
                  "day": "2",
                  "month": "1",
                  "entry": "Some text about Shoes for day 2 and month 1",
                  "code": "KKGIR"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 56500760
  },
  {
    "context": [
      "I want to use `jq` to get the value \"required\" field for each column. If the field \"required\" does not exist, it should return the default value `false`.",
      "How to implement this magic getOrDefault() function in `jq`?",
      "You can use the [alternative operator (`//`)](https://stedolan.github.io/jq/manual/#Alternativeoperator://) in this particular case.",
      "$ jq '.columns.description | .required // false' file",
      "To implement that functionality literally, you would use `has/1` rather than `//`, e.g.:",
      ".columns.id | if has(\"required\") then .required else false end",
      "def getOrDefault($key; $default): if has($key) then .[$key] else $default end;"
    ],
    "utterance": "Return the value of the 'required' field for a given column; if the field does not exist, return false.",
    "expressions": [
      ".required // false",
      "if has(\"required\") then .required else false end",
      "def getOrDefault($key; $default): if has($key) then .[$key] else $default end; . | getOrDefault(\"required\"; false)"
    ],
    "data": [
      {
        "input": {
          "columns": {
            "id": {
              "required": true,
              "type": "integer"
            },
            "name": {
              "required": false,
              "type": "string"
            },
            "description": {
              "type": "string"
            }
          }
        },
        "output": {
          "id": true,
          "name": false,
          "description": false
        }
      }
    ],
    "identifier": 56555155
  },
  {
    "context": [
      "How to take the names of the named array, insert them as elements into it, then remove the name?",
      "The names (`\"l1\"`, `\"l2\"`) are not known a priori, nor are the other contents; all I know is that I want to take the top-level names and insert them as `\"id\"`-named objects.",
      "You're on the right track thinking of `to_entries`:",
      "[to_entries[] | {id: .key} + .value]"
    ],
    "utterance": "Insert each top-level object's key as an array under 'id' inside the corresponding object, remove the original key, and output a flat list of these objects.",
    "expressions": [
      "[to_entries[] | {id: [.key]} + .value]"
    ],
    "data": [
      {
        "input": {
          "l1": {
            "v1": {
              "a": [
                1
              ],
              "b": [
                2
              ]
            },
            "v2": {
              "a": [
                3
              ],
              "b": [
                4
              ]
            }
          },
          "l2": {
            "v3": {
              "a": [
                5
              ],
              "b": [
                6
              ]
            },
            "v4": {
              "a": [
                7
              ],
              "b": [
                8
              ]
            }
          }
        },
        "output": [
          {
            "id": [
              "l1"
            ],
            "v1": {
              "a": [
                1
              ],
              "b": [
                2
              ]
            },
            "v2": {
              "a": [
                3
              ],
              "b": [
                4
              ]
            }
          },
          {
            "id": [
              "l2"
            ],
            "v3": {
              "a": [
                5
              ],
              "b": [
                6
              ]
            },
            "v4": {
              "a": [
                7
              ],
              "b": [
                8
              ]
            }
          }
        ]
      }
    ],
    "identifier": 56616171
  },
  {
    "context": [
      "$ jq '10.01 | round'",
      "jq: error: round/0 is not defined at <top-level>, line 1:",
      "Either upgrade jq or implement `round` using `floor`:",
      "def round: . + 0.5 | floor;",
      "$ jq -n 'def round: . + 0.5 | floor; 10.01 | round'",
      "We can use the pow function along with `. + 0.5 | floor` to create our own 'round' function that takes a value to round as input and the number of decimal places as argument.",
      "def round_whole:\n  . + 0.5 | floor\n;",
      "def round(num_dec):\n  num_dec as $num_dec |\n  . * pow(10; $num_dec) |\n  round_whole |\n  . / pow(10; $num_dec)\n;",
      "[\n  2.2362,\n  2.4642,\n  10.23423\n] |\nmap(\n  round(2)\n)",
      "Yields\n[\n  2.24,\n  2.46,\n  10.23\n]"
    ],
    "utterance": "Round a number to a specified number of decimal places when the built-in rounding function is unavailable.",
    "expressions": [
      "def round: . + 0.5 | floor; 10.01 | round",
      "def round_whole: . + 0.5 | floor; def round(num_dec): num_dec as $num_dec | . * pow(10; $num_dec) | round_whole | . / pow(10; $num_dec); [2.2362,2.4642,10.23423] | map(round(2))"
    ],
    "data": [
      {
        "input": 10.01,
        "output": 10
      },
      {
        "input": [
          2.2362,
          2.4642,
          10.23423
        ],
        "output": [
          2.24,
          2.46,
          10.23
        ]
      }
    ],
    "identifier": 56593531
  },
  {
    "context": [
      "I would like to get the `id` and the value of `name` if exists. So for that input, I would like to get the following output.",
      "{ \"id\": 1, \"name\": \"I am id 1\" } { \"id\": 2, \"name\": null }",
      "but although it extracts when it that key is present, it fails to give `null` or default value when the path doesn't exist.",
      "Any idea on how to solve this?",
      "{id, name: (.tags | if . then from_entries.Name else . end )}",
      "{id, name: (.tags | if . then from_entries.Name end )}",
      "{id, name: (.tags // {} | .[] | select(.Key==\"Name\").Value // null)}"
    ],
    "utterance": "Extract 'id' and the value of the 'Name' tag as 'name', or null if the tag or the tags array is missing.",
    "expressions": [
      "{id, name: (.tags | if . then from_entries.Name else . end )}",
      "{id, name: (.tags | if . then from_entries.Name end )}",
      "{id, name: (.tags // {} | .[] | select(.Key==\"Name\").Value // null)}"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "tags": [
            {
              "Key": "Name",
              "Value": "I am id 1"
            },
            {
              "Key": "Else",
              "Value": "Random"
            }
          ]
        },
        "output": {
          "id": 1,
          "name": "I am id 1"
        }
      },
      {
        "input": {
          "id": 2,
          "tags": null
        },
        "output": {
          "id": 2,
          "name": null
        }
      }
    ],
    "identifier": 56614969
  },
  {
    "context": [
      "I need to convert JSON to CSV where JSON has arrays of variable length, for example:",
      "JSON objects:",
      "    {\"labels\": [\"label1\"]}",
      "    {\"labels\": [\"label2\", \"label3\"]}",
      "    {\"labels\": [\"label1\", \"label4\", \"label5\"]}",
      "Resulting CSV:",
      "    labels,labels,labels",
      "    \"label1\",,",
      "    \"label2\",\"label3\",",
      "    \"label1\",\"label4\",\"label5\"",
      "I wanted to use jq with two passes, the first pass would collect the maximum length of the 'labels' array, the second pass would create CSV as the number of the resulting columns is known by this time.",
      "n=$(jq -n 'reduce (inputs|.labels|length) as $i (-1;\n  if $i > . then $i else . end)' stream.json)\njq -nr --argjson n $n '\n  def fill($n): . + [range(length;$n)|null];\n  [range(0;$n)|\"labels\"],\n  (inputs | .labels | fill($n))\n  | @csv' stream.json",
      "jq -n --stream \"reduce (inputs | .[0][1] + 1) as $l (0; if $l > . then $l else . end)\" input.json",
      "jq -rn --stream --argjson cols \"%cols%\" \"[range($cols)|\\\"labels\\\"],(fromstream(1|truncate_stream(inputs))|[.[],(range($cols-length)|null)])|@csv\" input.json"
    ],
    "utterance": "Convert a stream of objects containing a 'labels' array of variable length into CSV with columns equal to the maximum number of label elements, padding shorter arrays with empty values.",
    "expressions": [
      "jq -n 'reduce (inputs|.labels|length) as $i (-1; if $i > . then $i else . end)' stream.json",
      "jq -nr --argjson n $n 'def fill($n): . + [range(length;$n)|null]; [range(0;$n)|\"labels\"], (inputs | .labels | fill($n)) | @csv' stream.json",
      "jq -n --stream \"reduce (inputs | .[0][1] + 1) as $l (0; if $l > . then $l else . end)\" input.json",
      "jq -rn --stream --argjson cols \"%cols%\" \"[range($cols)|\\\"labels\\\"],(fromstream(1|truncate_stream(inputs))|[.[],(range($cols-length)|null)])|@csv\" input.json"
    ],
    "data": [
      {
        "input": [
          {
            "labels": [
              "label1"
            ]
          },
          {
            "labels": [
              "label2",
              "label3"
            ]
          },
          {
            "labels": [
              "label1",
              "label4",
              "label5"
            ]
          }
        ],
        "output": [
          [
            "labels",
            "labels",
            "labels"
          ],
          [
            "label1",
            "",
            ""
          ],
          [
            "label2",
            "label3",
            ""
          ],
          [
            "label1",
            "label4",
            "label5"
          ]
        ]
      }
    ],
    "identifier": 56569222
  },
  {
    "context": [
      "The task is to take the first Key and to combine it with the next Key's and their values:\n\nAgreement\nINFO:1458\nERROR:145",
      "Just map it to string.\n\n    jq --raw-output '.key, ( .level_cnt.buckets[] | \"\\(.key):\\(.doc_count)\" )'\n\nWith the following input:\n\n    {\n        \"key\": \"Agreement\",\n        \"doc_count\": 1603,\n        \"level_cnt\": {\n            \"doc_count_error_upper_bound\": 0,\n            \"sum_other_doc_count\": 0,\n            \"buckets\": [\n                {\n                \"key\": \"INFO\",\n                \"doc_count\": 1458\n              },\n              {\n                \"key\": \"ERROR\",\n                \"doc_count\": 145\n              }\n            ]\n        }\n    }\n\nwill output:\n\n    Agreement\n    INFO:1458\n    ERROR:145"
    ],
    "utterance": "Print the object's top-level key, then for each item in level_cnt.buckets print its key and doc_count in key:doc_count format.",
    "expressions": [
      ".key, ( .level_cnt.buckets[] | \"\\(.key):\\(.doc_count)\" )"
    ],
    "data": [
      {
        "input": {
          "key": "Agreement",
          "doc_count": 1603,
          "level_cnt": {
            "doc_count_error_upper_bound": 0,
            "sum_other_doc_count": 0,
            "buckets": [
              {
                "key": "INFO",
                "doc_count": 1458
              },
              {
                "key": "ERROR",
                "doc_count": 145
              }
            ]
          }
        },
        "output": [
          "Agreement",
          "INFO:1458",
          "ERROR:145"
        ]
      }
    ],
    "identifier": 56648694
  },
  {
    "context": [
      "Source:",
      "{\n  \"title\": \"title\",\n  \"keyword\": \"keyword\",\n  \"desc\": {\n    \"user1\": {\n      \"name\": \"kumar\",\n      \"Duration\": null,\n      \"Time\": null,\n      \" Dominance\": \"Upper Field First\"\n    },\n    \"user2\": {\n      \"id\": \"user2\",\n      \"name\": \"user2\",\n      \"Duration\": null,\n      \"Time\": null,\n      \" Dominance\": \"Upper Field First\"\n    }\n  }\n}",
      "Target:",
      "[\n  {\n    \"id\": \"user1\",\n    \"name\": \"kumar\",\n    \"Duration\": null,\n    \"Time\": null,\n    \"Dominance\": \"Upper Field First\"\n  },\n  {\n    \"id\": \"user2\",\n    \"name\": \"user2\",\n    \"Duration\": null,\n    \"Time\": null,\n    \"Dominance\": \"Upper Field First\"\n  }\n]",
      "The following filter will do what you want, assuming you've fixed the input:",
      ".desc\n| to_entries\n| map( {id: .key} + .value)"
    ],
    "utterance": "Convert the desc object from keyed sub-objects to a list of objects, assigning each key to an id field and standardizing property names (removing leading spaces).",
    "expressions": [
      ".desc | to_entries | map({id: .key} + (.value | with_entries(.key |= ltrimstr(\" \"))))"
    ],
    "data": [
      {
        "input": {
          "title": "title",
          "keyword": "keyword",
          "desc": {
            "user1": {
              "name": "kumar",
              "Duration": null,
              "Time": null,
              " Dominance": "Upper Field First"
            },
            "user2": {
              "id": "user2",
              "name": "user2",
              "Duration": null,
              "Time": null,
              " Dominance": "Upper Field First"
            }
          }
        },
        "output": [
          {
            "id": "user1",
            "name": "kumar",
            "Duration": null,
            "Time": null,
            "Dominance": "Upper Field First"
          },
          {
            "id": "user2",
            "name": "user2",
            "Duration": null,
            "Time": null,
            "Dominance": "Upper Field First"
          }
        ]
      }
    ],
    "identifier": 56638907
  },
  {
    "context": [
      "Above is a jq command that I want to use to extract email addresses, the desired output is \"SMTP:russell.coker@example.com\" printed once not 9 times.",
      "`unique/0` could be used if you don't mind the fact that it sorts its input.  This filter expects an array as input, and so you could modify your query as follows:",
      "[.[]\n | select(.accountEnabled==true)\n | select(.assignedPlans[].service==\"exchange\" and .assignedPlans[].capabilityStatus==\"Enabled\")\n | .proxyAddresses[]]\n| unique",
      ".[]\n| select(.accountEnabled==true)\n| select(any(.assignedPlans[];\n             .service==\"exchange\" and\n             .capabilityStatus==\"Enabled\"))\n| .proxyAddresses[]"
    ],
    "utterance": "Extract all proxyAddresses for users with accountEnabled true and at least one assignedPlan with service equal to exchange and capabilityStatus equal to Enabled, ensuring each address appears only once.",
    "expressions": [
      "[.[] | select(.accountEnabled==true) | select(.assignedPlans[].service==\"exchange\" and .assignedPlans[].capabilityStatus==\"Enabled\") | .proxyAddresses[]] | unique",
      ".[] | select(.accountEnabled==true) | select(any(.assignedPlans[]; .service==\"exchange\" and .capabilityStatus==\"Enabled\")) | .proxyAddresses[]"
    ],
    "data": [
      {
        "input": [
          {
            "accountEnabled": true,
            "assignedPlans": [
              {
                "capabilityStatus": "Enabled",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Enabled",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Enabled",
                "service": "exchange"
              }
            ],
            "provisionedPlans": [
              {
                "capabilityStatus": "Enabled",
                "provisioningStatus": "Success",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Enabled",
                "provisioningStatus": "Success",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Enabled",
                "provisioningStatus": "Success",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Enabled",
                "provisioningStatus": "Success",
                "service": "exchange"
              }
            ],
            "proxyAddresses": [
              "SMTP:russell.coker@example.com"
            ]
          },
          {
            "accountEnabled": true,
            "assignedPlans": [
              {
                "capabilityStatus": "Deleted",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Deleted",
                "service": "OfficeForms"
              }
            ],
            "provisionedPlans": [
              {
                "capabilityStatus": "Deleted",
                "provisioningStatus": "Success",
                "service": "SharePoint"
              },
              {
                "capabilityStatus": "Deleted",
                "provisioningStatus": "Success",
                "service": "exchange"
              },
              {
                "capabilityStatus": "Deleted",
                "provisioningStatus": "Success",
                "service": "exchange"
              }
            ],
            "proxyAddresses": [
              "smtp:a@example.com",
              "smtp:b@example.com",
              "SMTP:c@example.com"
            ]
          }
        ],
        "output": [
          "SMTP:russell.coker@example.com"
        ]
      }
    ],
    "identifier": 56626848
  },
  {
    "context": [
      "I'm getting this string data from `curl` command",
      "{ \"password\": [[\"passwordreal\", \"2035/01/01 00:00\"]], \"user\": \"user1\", \"address\": \"kobebkokoko.net\" }",
      "How do I get `passwordreal` using `sed`?",
      "With jq:\n\n    | jq -r '.password[]|.[0]'",
      "Output:\npasswordreal"
    ],
    "utterance": "Extract the first value from the first array inside the 'password' key when it is a nested array.",
    "expressions": [
      ".password[] | .[0]"
    ],
    "data": [
      {
        "input": {
          "password": [
            [
              "passwordreal",
              "2035/01/01 00:00"
            ]
          ],
          "user": "user1",
          "address": "kobebkokoko.net"
        },
        "output": "passwordreal"
      }
    ],
    "identifier": 56676743
  },
  {
    "context": [
      "Suppose I have the following JSON array:",
      "The first item of the array **always** represents the *\"columns\"*, while the other items are the rows.",
      "I\u2019d like to transform the above JSON into something more readable, i.e. getting rid of the first item altogether, merging all the separated objects and also udpating the field name accordingly:",
      "Ideally, I\u2019d like to achieve this with a CLI tool such as **jq** - is this possible?",
      "This is exactly what I was looking for. I\u2019ve enhanced your example with this version that is not coupled to the # of columns:\n\n```\n[.[0][].value] as $cols | [.[1:][] | to_entries] | map(map({($cols[.key]): .value.value}) | add)\n```",
      "Here\u2019s another way you can construct the desired results.\n\n    (.[0] | map({key:.value})) as $keys | [.[1:][] | [$keys,.] | transpose | map(add) | from_entries]"
    ],
    "utterance": "Transform a two-dimensional array where the first sub-array contains column names (as objects with a 'value' key) and subsequent sub-arrays contain rows (also as objects with a 'value' key), into a list of objects mapping columns to values for each row.",
    "expressions": [
      "[.[0][].value] as $cols | [.[1:][] | to_entries] | map(map({($cols[.key]): .value.value}) | add)",
      "(.[0] | map({key:.value})) as $keys | [.[1:][] | [$keys,.] | transpose | map(add) | from_entries"
    ],
    "data": [
      {
        "input": [
          [
            {
              "value": "first_name"
            },
            {
              "value": "last_name"
            },
            {
              "value": "age"
            }
          ],
          [
            {
              "value": "John"
            },
            {
              "value": "Johnson"
            },
            {
              "value": 27
            }
          ],
          [
            {
              "value": "Martin"
            },
            {
              "value": "Martinson"
            },
            {
              "value": 18
            }
          ]
        ],
        "output": [
          {
            "first_name": "John",
            "last_name": "Johnson",
            "age": 27
          },
          {
            "first_name": "Martin",
            "last_name": "Martinson",
            "age": 18
          }
        ]
      }
    ],
    "identifier": 56652066
  },
  {
    "context": [
      "I want to get different values from a json file with jq but i can't get values which are in a different level.",
      "I can get id / user but i can't get the date field.",
      "jq '.executions[0] | .date-started.date' response.json",
      "$ jq -r '[.id, .user, .\"date-started\".date] | join(\" \")' input.json",
      "jq '.executions[0] | \"\\(.id) \\(.user) \\(.\\\"date-started\\\".date)\"' response.json"
    ],
    "utterance": "Extract the id, user, and the date field inside date-started from the first element under executions, with the output on a single line.",
    "expressions": [
      ".executions[0] | \"\\(.id) \\(.user) \\(.\"date-started\".date)\"",
      "[.id, .user, .\"date-started\".date] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "executions": [
            {
              "id": 132,
              "status": "succeeded",
              "project": "TEST-Sylvain",
              "executionType": "user",
              "user": "sthirard",
              "date-started": {
                "unixtime": 1560946609000,
                "date": "2019-06-19T12:16:49Z"
              },
              "date-ended": {
                "unixtime": 1560946613000,
                "date": "2019-06-19T12:16:53Z"
              },
              "job": {
                "id": "7a8dfbb0-a4b1-4309-8b76-f04cd0f03af2",
                "averageDuration": 3060,
                "name": "TEST_chainage_job",
                "group": "DEPLOYMENT",
                "project": "TEST-Sylvain",
                "description": "JOb d'installation  "
              },
              "description": "hostname [... 4 steps]",
              "argstring": null,
              "successfulNodes": [
                "acde",
                "bfgh"
              ]
            }
          ]
        },
        "output": "132 sthirard 2019-06-19T12:16:49Z"
      }
    ],
    "identifier": 56668919
  },
  {
    "context": [
      "Every `JSON` object in the file is supposed to be converted to a single `CSV` row, and I can't get that to work.",
      "For instance, I could have a JSON file resembling:\n\n{resources:[\n    {\"id\":\"001\",\"name\"=\"Robert\",\"items\":[\n        {\"label\":\"00A\",\"name\":\"Pen\"},\n        {\"label\":\"00B\",\"name\":\"Paper\"}],\n    {\"id\":\"002\",\"name\"=\"Bruce\",\"items\":[\n        {\"label\":\"00A\",\"name\":\"Pen\"},\n        {\"label\":\"00B\",\"name\":\"Computer\"},\n        {\"label\":\"00C\",\"name\":\"Headphones\"}]\n]\n}",
      "That I would like to become:\n001,Robert,Pen,Paper,\n002,Bruce,Pen,Computer,Headphones",
      "I only need the `name` columns of the array",
      "$ jq -r '.resources[] | [.id,.name,.items[].name] | @csv' < /tmp/b.json\n\"001\",\"Robert\",\"Pen\",\"Paper\"\n\"002\",\"Bruce\",\"Pen\",\"Computer\",\"Headphones\""
    ],
    "utterance": "Convert each object to a single CSV row with id, name, followed by the names of each item in its items array.",
    "expressions": [
      ".resources[] | [.id,.name,.items[].name] | @csv"
    ],
    "data": [
      {
        "input": {
          "resources": [
            {
              "id": "001",
              "name": "Robert",
              "items": [
                {
                  "label": "00A",
                  "name": "Pen"
                },
                {
                  "label": "00B",
                  "name": "Paper"
                }
              ]
            },
            {
              "id": "002",
              "name": "Bruce",
              "items": [
                {
                  "label": "00A",
                  "name": "Pen"
                },
                {
                  "label": "00B",
                  "name": "Computer"
                },
                {
                  "label": "00C",
                  "name": "Headphones"
                }
              ]
            }
          ]
        },
        "output": [
          "\"001\",\"Robert\",\"Pen\",\"Paper\"",
          "\"002\",\"Bruce\",\"Pen\",\"Computer\",\"Headphones\""
        ]
      }
    ],
    "identifier": 56671337
  },
  {
    "context": [
      "\"In these files, there are no brackets surrounding the entire text within the file.\"",
      "\"If there isn't an outer array or object, you can't use `.[]`.\"",
      "\"A version cut down to remove the broken parts might look like:\"",
      "a=\"google.com\" jq -r '\nif (.host | contains(env.a)) then\n  [.\"ip.A\",.\"ts\",.\"ip.B\"] | @tsv\nelse\n  empty\nend\n' <<'EOF'\n{\n  \"ts\": \"2019-06-19T00:00:00.000000Z\",\n  \"ip.A\": \"0.0.0.0\",\n  \"ip.B\": \"0.0.0.0\",\n  \"host\": \"www.google.com\"\n}\nEOF"
    ],
    "utterance": "For each object, output ip.A, ts, and ip.B separated by tabs if the host contains the given substring.",
    "expressions": [
      "if (.host | contains(env.a)) then [.\"ip.A\", .\"ts\", .\"ip.B\"] | @tsv else empty end"
    ],
    "data": [
      {
        "input": {
          "ts": "2019-06-19T00:00:00.000000Z",
          "ip.A": "0.0.0.0",
          "ip.B": "0.0.0.0",
          "host": "www.google.com"
        },
        "output": "0.0.0.0\t2019-06-19T00:00:00.000000Z\t0.0.0.0"
      }
    ],
    "identifier": 56675409
  },
  {
    "context": [
      "The top-level `image` property should be used as a prefix for the `description` of every object in the `vulnerabilities` list.",
      "Unfortunately, I only get the `description` field back with my current filter. I want the full vulnerability object with the modified `description` field.",
      "How can I concatenate the nested field and keep the other properties of the object too?",
      "The simplest solution would probably be:\n\n    .image as $prefix\n    | .vulnerabilities[].description |= $prefix + \" - \" + .\n",
      "Equivalently, and perhaps less esoterically:\n\n    .image as $prefix\n    | .vulnerabilities |= map(.description |= $prefix + \" - \" + .)"
    ],
    "utterance": "For each object in vulnerabilities, prepend the top-level image property and a separator to its description field, keeping all other fields unchanged.",
    "expressions": [
      ".image as $prefix | .vulnerabilities |= map(.description |= $prefix + \" - \" + .)"
    ],
    "data": [
      {
        "input": {
          "image": "golang:1.3",
          "unapproved": [
            "CVE-2016-5421",
            "CVE-2019-5010"
          ],
          "vulnerabilities": [
            {
              "featurename": "curl",
              "featureversion": "7.38.0-4+deb8u2",
              "vulnerability": "CVE-2016-5421",
              "namespace": "debian:8",
              "description": "Use-after-free vulnerability in libcurl before 7.50.1 allows attackers to control which connection is used or possibly have unspecified other impact via unknown vectors.",
              "link": "https://security-tracker.debian.org/tracker/CVE-2016-5421",
              "severity": "High",
              "fixedby": "7.38.0-4+deb8u4"
            },
            {
              "featurename": "python2.7",
              "featureversion": "2.7.9-2",
              "vulnerability": "CVE-2019-5010",
              "namespace": "debian:8",
              "description": "Test description",
              "link": "https://security-tracker.debian.org/tracker/CVE-2019-5010",
              "severity": "Unknown",
              "fixedby": ""
            }
          ]
        },
        "output": {
          "image": "golang:1.3",
          "unapproved": [
            "CVE-2016-5421",
            "CVE-2019-5010"
          ],
          "vulnerabilities": [
            {
              "featurename": "curl",
              "featureversion": "7.38.0-4+deb8u2",
              "vulnerability": "CVE-2016-5421",
              "namespace": "debian:8",
              "description": "golang:1.3 - Use-after-free vulnerability in libcurl before 7.50.1 allows attackers to control which connection is used or possibly have unspecified other impact via unknown vectors.",
              "link": "https://security-tracker.debian.org/tracker/CVE-2016-5421",
              "severity": "High",
              "fixedby": "7.38.0-4+deb8u4"
            },
            {
              "featurename": "python2.7",
              "featureversion": "2.7.9-2",
              "vulnerability": "CVE-2019-5010",
              "namespace": "debian:8",
              "description": "golang:1.3 - Test description",
              "link": "https://security-tracker.debian.org/tracker/CVE-2019-5010",
              "severity": "Unknown",
              "fixedby": ""
            }
          ]
        }
      }
    ],
    "identifier": 56684251
  },
  {
    "context": [
      "And would like to output empty and/or null values and their keys:",
      "The tricky part here is emitting the keys without quotation marks in a way that the empty string is shown with quotation marks.  Here is one solution that works with jq's -r command-line option:",
      "to_entries[]\n| select(.value | . == null or . == \"\")\n| if .value == \"\" then .value |= \"\\\"\\(.)\\\"\" else . end\n| \"\\(.key): \\(.value)\"",
      "Some people may find the following jq program more useful for identifying keys with null or empty string values:\n\n    with_entries(select(.value |.==null or . == \"\"))",
      "With the sample input, this program would produce:\n{\"available\":\"\"}\n{\"color\":null}"
    ],
    "utterance": "List all key-value pairs where the value is either an empty string or null, showing the key and the corresponding value.",
    "expressions": [
      "to_entries[] | select(.value == null or .value == \"\") | if .value == \"\" then .value |= \"\\\"\\(.)\\\"\" else . end | \"\\(.key): \\(.value)\"",
      "with_entries(select(.value == null or .value == \"\"))"
    ],
    "data": [
      {
        "input": {
          "name": "Color TV",
          "price": "1200",
          "available": ""
        },
        "output": [
          "available: \"\""
        ]
      },
      {
        "input": {
          "name": "DVD player",
          "price": "200",
          "color": null
        },
        "output": [
          "color: null"
        ]
      }
    ],
    "identifier": 56692037
  },
  {
    "context": [
      "I\u2019m far from my desired output since I\u2019d like to extract the children for each parent and tabulate in the form below.",
      "| N1   | N2   | NR_i  | NR_f    | N1  | N2  | NR_i  | NR_f | N1  | N2   | NR_i | NR_f |",
      "393  | 720  | 203   | 49994   | 649 | 111 | 55400 | 877  | 748 | 5624 | 8746 | 7773 |",
      "Since the nature of the input JSON has only been given by example, let's begin by defining a filter for linearizing `.NR`:",
      "def linearize:\n  if type == \"array\" then .[] | linearize\n  else [ .N1, .N2, .SNR.NR_i, .SNR.NR_f]\n  end;",
      ".Main.List.SubList.ND.RiS.RiN.NSE14\n| [to_entries[]\n| [.key]\n  + [.value | .. | objects | select(has(\"NR\")) | .NR | [ linearize ]] ]",
      "| map(if length > 2 then [.[0], [.[1:][][]]] else . end)",
      "def row($i; $padding):\n  . as $in\n  | [range(0;$padding) | null] as $nulls\n  | reduce range(0; length) as $ix \n      ([]; . + ($in[$ix][1][$i] // $nulls));",
      "| (map(.[1] | length) | max) as $rows\n| range(0; $rows) as $r\n| row($r; 4)\n| @tsv"
    ],
    "utterance": "Tabulate all N1, N2, NR_i, and NR_f values for MNRs, GNRs, and MSNRs side by side in rows, filling missing values with empty fields so each group\u2019s data aligns by column.",
    "expressions": [
      "def linearize:\n  if type == \"array\" then .[] | linearize\n  else [ .N1, .N2, .SNR.NR_i, .SNR.NR_f]\n  end;\n\n.Main.List.SubList.ND.RiS.RiN.NSE14\n| [to_entries[]\n| [.key] + [.value | .. | objects | select(has(\"NR\")) | .NR | [ linearize ]] ]\n| map(if length > 2 then [.[0], [.[1:][][]]] else . end)\n| (map(.[1] | length) | max) as $rows\n| range(0; $rows) as $r\n| def row($i; $padding):\n    . as $in\n    | [range(0;$padding) | null] as $nulls\n    | reduce range(0; length) as $ix \n        ([]; . + ($in[$ix][1][$i] // $nulls));\n  row($r; 4)\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "Main": {
            "Document": "Doc.1",
            "Cini": "DDFR",
            "List": {
              "SubList": {
                "CdTa": "ABC",
                "NN": "XYZ",
                "ND": {
                  "RiS": {
                    "RiN": {
                      "NSE14": {
                        "MNRs": {
                          "MRD": [
                            {
                              "NR": {
                                "N1": "393",
                                "N2": "720",
                                "SNR": {
                                  "NR_i": "203",
                                  "NR_f": "49994"
                                }
                              }
                            },
                            {
                              "NR": {
                                "N1": "687",
                                "N2": "345",
                                "SNR": {
                                  "NR_i": "55005",
                                  "NR_f": "1229996"
                                }
                              }
                            }
                          ]
                        },
                        "GNRs": {
                          "RD": {
                            "NR": {
                              "N1": "649",
                              "N2": "111",
                              "SNR": {
                                "NR_i": "55400",
                                "NR_f": "877"
                              }
                            }
                          }
                        },
                        "MSNRs": {
                          "NR": [
                            {
                              "N1": "748",
                              "N2": "5624",
                              "SNR": {
                                "NR_i": "8746",
                                "NR_f": "7773"
                              }
                            },
                            {
                              "N1": "124",
                              "N2": "54",
                              "SNR": {
                                "NR_i": "8847",
                                "NR_f": "5526"
                              }
                            }
                          ]
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": [
          "393\t720\t203\t49994\t649\t111\t55400\t877\t748\t5624\t8746\t7773",
          "687\t345\t55005\t1229996\t\t\t\t\t124\t54\t8847\t5526"
        ]
      }
    ],
    "identifier": 56468581
  },
  {
    "context": [
      "\"I need to transform an array by adding additional objects -\r\n\r\n**I have:**\r\n\r\n    \\\"user_id\\\":\\\"testuser\\\"\r\n    \\\"auth_token\\\":\\\"abcd\\\"\r\n\r\n**I need:**\r\n\r\n    \\\"key\\\":\\\"user_id\\\"\r\n    \\\"value\\\":\\\"testuser\\\"\r\n    \\\"key\\\":\\\"auth_token\\\"\r\n    \\\"value\\\":\\\"abcd\\\"\"",
      "\"You could get an array of key/value pair objects using `to_entries`.\"",
      "\"$ jq 'to_entries' input.json\r\n[\r\n    {\r\n        \\\"key\\\": \\\"user_id\\\",\r\n        \\\"value\\\": \\\"testuser\\\"\r\n    },\r\n    {\r\n        \\\"key\\\": \\\"auth_token\\\",\r\n        \\\"value\\\": \\\"abcd\\\"\r\n    }\r\n]\""
    ],
    "utterance": "Convert an object with properties user_id: \"testuser\" and auth_token: \"abcd\" into an array of objects each containing key and value fields for each property.",
    "expressions": [
      "to_entries"
    ],
    "data": [
      {
        "input": {
          "user_id": "testuser",
          "auth_token": "abcd"
        },
        "output": [
          {
            "key": "user_id",
            "value": "testuser"
          },
          {
            "key": "auth_token",
            "value": "abcd"
          }
        ]
      }
    ],
    "identifier": 56701692
  },
  {
    "context": [
      "I\u2019m now trying to group the objects based on the value of a shared key. Then, for each array of grouped objects, create a new object where the array is the value of a new key.",
      "This is where I'm trying (painfully) to get to:",
      "[ { \"new_key1\":\"group_val1\", \"new_key2\":[ ... ] }, { \"new_key1\":\"group_val2\", \"new_key2\":[ ... ] } ]",
      "The filter you're evidently looking for is simpler than you might think:",
      "group_by(.group_key) | map( {new_key1: .[0].group_key, new_key2: .} )"
    ],
    "utterance": "Group array elements by group_key, and produce an array of objects each with new_key1 set to the group value and new_key2 set to the array of grouped objects.",
    "expressions": [
      "group_by(.group_key) | map({new_key1: .[0].group_key, new_key2: .})"
    ],
    "data": [
      {
        "input": [
          {
            "any_key": "any_value",
            "group_key": "group_val1"
          },
          {
            "any_key": "any_value",
            "group_key": "group_val1"
          },
          {
            "any_key": "any_value",
            "group_key": "group_val2"
          },
          {
            "any_key": "any_value",
            "group_key": "group_val2"
          }
        ],
        "output": [
          {
            "new_key1": "group_val1",
            "new_key2": [
              {
                "any_key": "any_value",
                "group_key": "group_val1"
              },
              {
                "any_key": "any_value",
                "group_key": "group_val1"
              }
            ]
          },
          {
            "new_key1": "group_val2",
            "new_key2": [
              {
                "any_key": "any_value",
                "group_key": "group_val2"
              },
              {
                "any_key": "any_value",
                "group_key": "group_val2"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 56701545
  },
  {
    "context": [
      "Trying to select objects from JSON array where value contains a string and value is not null.",
      "curl blah | jq ' .certificates[] | select(.variable_path|test(\"thing\"))'",
      "jq: error (at <stdin>:0): null (null) cannot be matched, as it is not a string",
      "One way to remove the `null` values from consideration would be:",
      ".certificates[] | select(.variable_path | strings | test(\"thing\"))",
      "You could also consider using `?`, which could be used here like this:",
      ".certificates[] | select(.variable_path | test(\"thing\")?)"
    ],
    "utterance": "Select objects from the certificates array where the variable_path field contains the string 'thing' and is not null.",
    "expressions": [
      ".certificates[] | select(.variable_path | strings | test(\"thing\"))",
      ".certificates[] | select(.variable_path | test(\"thing\")?)"
    ],
    "data": [
      {
        "input": {
          "certificates": [
            {
              "configurable": false,
              "property_reference": ".properties.director_ssl",
              "property_type": "rsa_cert_credentials",
              "product_guid": "p-blah-29d4678e926cf2069871",
              "location": "ops_manager",
              "variable_path": null,
              "issuer": "/C=US/O=Blah",
              "valid_from": "2019-01-16T19:55:10Z",
              "valid_until": "2021-01-16T19:55:10Z"
            },
            {
              "configurable": false,
              "property_reference": ".properties.uaa_ssl",
              "property_type": "rsa_cert_credentials",
              "product_guid": "p-blah-29d4678e926cf2069871",
              "location": "ops_manager",
              "variable_path": null,
              "issuer": "/C=US/O=Blah",
              "valid_from": "2019-01-16T19:55:10Z",
              "valid_until": "2021-01-16T19:55:10Z"
            },
            {
              "configurable": false,
              "property_reference": ".properties.blobstore_certificate",
              "property_type": "rsa_cert_credentials",
              "product_guid": "p-blah-29d4678e926cf2069871",
              "location": "ops_manager",
              "variable_path": "something",
              "issuer": "/C=US/O=Blah",
              "valid_from": "2019-01-16T19:55:11Z",
              "valid_until": "2021-01-16T19:55:11Z"
            }
          ]
        },
        "output": {
          "configurable": false,
          "property_reference": ".properties.blobstore_certificate",
          "property_type": "rsa_cert_credentials",
          "product_guid": "p-blah-29d4678e926cf2069871",
          "location": "ops_manager",
          "variable_path": "something",
          "issuer": "/C=US/O=Blah",
          "valid_from": "2019-01-16T19:55:11Z",
          "valid_until": "2021-01-16T19:55:11Z"
        }
      }
    ],
    "identifier": 56690455
  },
  {
    "context": [
      "What I'm trying to get to is:\n\n    [\n       {\n          \"key1\":\"value1\",\n          \"key2\":\"value2\",\n          \"key_to_be_extracted_1\":\"value_to_be_extracted_1\",\n          \"key_to_be_extracted_2\":\"value_to_be_extracted_2\"\n       },\n       {\n          \"key1\":\"value1\",\n          \"key2\":\"value2\",\n          \"key_to_be_extracted_1\":\"value_to_be_extracted_1\",\n          \"key_to_be_extracted_2\":\"value_to_be_extracted_2\"\n       }\n    ]",
      "jq has a `from_entries` function that expects an array of `{key, value}` objects and produces an object. Thus, you can transform your \"key 3\" value into such an array and produce an object like so:\n\n`.\"key 3\" | map({key: .a, value: .v} | from_entries`\n\nPutting that together with a map that just copies the two other keys:\n\n`map({key1, key2} + (.\"key 3\" | map({key: .a, value: .v}) | from_entries))`",
      "If you want to avoid having to specify the keys to retain, you could go with:\n\n    map( .\n         + (.\"key 3\" | map( {(.a): .v} ) | add )\n         | del(.\"key 3\") )\n\n\nThat is, add in the new key-value pairs, and then delete \"key 3\". Notice also that `add` has been used here instead of `from_entries`, making for a more succinct and perhaps more straightforward solution."
    ],
    "utterance": "Transform each object in an array so that all key-value pairs from the nested array under \"key 3\" using properties 'a' as key and 'v' as value are merged into the top-level object.",
    "expressions": [
      "map({key1, key2} + (.\"key 3\" | map({key: .a, value: .v}) | from_entries))",
      "map(. + (.\"key 3\" | map({(.a): .v}) | add) | del(.\"key 3\"))"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1",
            "key2": "value2",
            "key 3": [
              {
                "a": "key_to_be_extracted_1",
                "v": "value_to_be_extracted_1"
              },
              {
                "a": "key_to_be_extracted_2",
                "v": "value_to_be_extracted_2"
              }
            ]
          },
          {
            "key1": "value1",
            "key2": "value2",
            "key 3": [
              {
                "a": "key_to_be_extracted_1",
                "v": "value_to_be_extracted_1"
              },
              {
                "a": "key_to_be_extracted_2",
                "v": "value_to_be_extracted_2"
              }
            ]
          }
        ],
        "output": [
          {
            "key1": "value1",
            "key2": "value2",
            "key_to_be_extracted_1": "value_to_be_extracted_1",
            "key_to_be_extracted_2": "value_to_be_extracted_2"
          },
          {
            "key1": "value1",
            "key2": "value2",
            "key_to_be_extracted_1": "value_to_be_extracted_1",
            "key_to_be_extracted_2": "value_to_be_extracted_2"
          }
        ]
      }
    ],
    "identifier": 56699742
  },
  {
    "context": [
      "Now, I want to capture only those ids who have dummy value of \"This is dummy\".",
      "to capture only those ids who have dummy value of \"This is dummy\"",
      ".[] | select( any(.[]; .dummy == \"This is dummy\") ) | add | .id",
      ".[] | select( any(.[]; .dummy == \"This is dummy\") ) | .[] | .id? // empty"
    ],
    "utterance": "Extract the id values from inner arrays where at least one object has dummy equal to \"This is dummy\".",
    "expressions": [
      ".[] | select( any(.[]; .dummy == \"This is dummy\") ) | add | .id",
      ".[] | select( any(.[]; .dummy == \"This is dummy\") ) | .[] | .id? // empty"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "abcd"
            },
            {
              "address": [
                "140 Deco st"
              ]
            }
          ],
          [
            {
              "id": "xyz"
            },
            {
              "dummy": "This is dummy"
            }
          ],
          [
            {
              "id": "12356"
            },
            {
              "address": [
                "140 Deco st"
              ]
            }
          ]
        ],
        "output": [
          "xyz"
        ]
      }
    ],
    "identifier": 56712193
  },
  {
    "context": [
      "I want to use jq to merge multiple files and if more than one file contains an array with the name, I need the arrays merged (order doesn\u2019t matter).",
      "I also need a solution that doesn\u2019t require specifying the fields that are arrays, and the arrays can be nested at any level of the json",
      "Here is a simple but generic solution to the problem in the case of two files, each with one object.",
      "This solution will concatenate each pair of arrays at the same path.",
      "jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '\n  $file1[0] as $f1\n  | $file2[0] as $f2\n  | reduce ($f1 | paths) as $p ($f1+$f2;\n      ($f1|getpath($p)) as $v1\n      | ($f2|getpath($p)) as $v2\n      | if ($v1 | type == \"array\") and\n           ($v2 | type == \"array\")\n        then setpath($p; $v1 + $v2)\n        else .\n        end)\n\n'"
    ],
    "utterance": "Merge two objects so that all arrays with matching paths are concatenated, at any nesting level, without needing to specify the array fields.",
    "expressions": [
      "jq -n --slurpfile file1 file1.json --slurpfile file2 file2.json '\n  $file1[0] as $f1\n  | $file2[0] as $f2\n  | reduce ($f1 | paths) as $p ($f1+$f2;\n      ($f1|getpath($p)) as $v1\n      | ($f2|getpath($p)) as $v2\n      | if ($v1 | type == \"array\") and\n           ($v2 | type == \"array\")\n        then setpath($p; $v1 + $v2)\n        else .\n        end)\n\n'"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "value1": 200,
            "timestamp": 1382461861,
            "parameter": [
              {
                "param": 1
              }
            ]
          },
          "file2.json": {
            "status": 200,
            "timestamp": 1382461861,
            "value": {
              "aaa": {
                "value3": "v3",
                "value4": 4
              }
            },
            "parameter": [
              {
                "param": 2
              }
            ]
          }
        },
        "output": {
          "value1": 200,
          "timestamp": 1382461861,
          "parameter": [
            {
              "param": 1
            },
            {
              "param": 2
            }
          ],
          "status": 200,
          "value": {
            "aaa": {
              "value3": "v3",
              "value4": 4
            }
          }
        }
      }
    ],
    "identifier": 56651743
  },
  {
    "context": [
      "However, as pointed out in a comment by Cyrus, you probably don't need to iterate line-by-line in a shell loop, which is incredibly inefficient since it leads to reparsing the entire JSON input many times. You can use jq itself to iterate, with the much simpler:",
      "jq '.issues[].line' solar-response.json",
      "which will parse the JSON file just once, and then produce each `.line` value in the file."
    ],
    "utterance": "Extract all line values from each object in the issues array.",
    "expressions": [
      ".issues[].line"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "016B7970D27939AEBD",
              "component": "bits-and-bytes:src/main/java/com/catalystone/statusreview/handler/StatusReviewDecisionLedHandler.java",
              "line": 15,
              "startLine": 15,
              "startOffset": 12,
              "endLine": 15,
              "endOffset": 14,
              "message": "Use the \"equals\" method if value comparison was intended.",
              "severity": "MAJOR",
              "rule": "squid:S4973",
              "status": "OPEN",
              "isNew": true,
              "creationDate": "2019-06-21T15:19:18+0530"
            },
            {
              "key": "AWtqCc-jtovxS8PJjBiP",
              "component": "bits-and-bytes:src/test/java/com/catalystone/statusreview/service/StatusReviewInitiationSerivceTest.java",
              "message": "Fix failing unit tests on file \"src/test/java/com/catalystone/statusreview/service/StatusReviewInitiationSerivceTest.java\".",
              "severity": "MAJOR",
              "rule": "common-java:FailedUnitTests",
              "status": "OPEN",
              "isNew": false,
              "creationDate": "2019-06-18T15:32:08+0530"
            }
          ]
        },
        "output": [
          15,
          null
        ]
      }
    ],
    "identifier": 56716155
  },
  {
    "context": [
      "The desired output would look like:\r\n{\r\n  \"FirstItem1\": \"Item 1\",\r\n  \"SecondItem1\": \"Second Item 1\"\r\n}",
      "I can return each item individually by using\r\n.[0] | {FirstItem1: .[0].items[0].firstitem1}",
      ".[1] | {seconditem: .[0].items[0].seconditem1}",
      "You just need an extra pair of parentheses:\r\n    (.[0] | {FirstItem1: .[0].items[0].firstitem1}) + \r\n    (.[1] | {seconditem: .[0].items[0].seconditem1})\r\n\r\nExcept you probably meant \"SecondItem1\" for the second key name.",
      "Here's a less repetitive solution:\r\n    [.[][] | .items[0]]\r\n    | {FirstItem1: first(.[0][]), SecondItem1: first(.[1][])}"
    ],
    "utterance": "Extract the first item name from the first and second nested array objects and return them as {FirstItem1: <value>, SecondItem1: <value>}.",
    "expressions": [
      "(.[0] | {FirstItem1: .[0].items[0].firstitem1}) + (.[1] | {SecondItem1: .[0].items[0].seconditem1})",
      "[.[][] | .items[0]] | {FirstItem1: .[0].firstitem1, SecondItem1: .[1].seconditem1}"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Item": "FIRST",
              "items": [
                {
                  "firstitem1": "Item 1",
                  "firstitem2": "Item 2"
                }
              ]
            }
          ],
          [
            {
              "Item": "SECOND",
              "items": [
                {
                  "seconditem1": "Second Item 1",
                  "seconditem2": "Second Item 2"
                }
              ]
            }
          ]
        ],
        "output": {
          "FirstItem1": "Item 1",
          "SecondItem1": "Second Item 1"
        }
      }
    ],
    "identifier": 56720304
  }
]