[
  {
    "context": [
      "I have an aws query where I want to filter all the `imageTags` that **don't** end with *latest*.",
      "I tried this, but it filters things containing *latest*, where I want to filter things **not** containing *latest* (or **not** ending with *latest*):",
      "You can use `not` to reverse the logic",
      "(.imageTags[] | contains(\\\"latest\\\") | not)",
      "is better use the `not` of `index()` function",
      "select(.imageTags | index(\"latest\") | not)"
    ],
    "utterance": "Select items whose array field 'imageTags' does not contain the value 'latest'.",
    "expressions": [
      "select(.imageTags | index(\"latest\") | not)",
      ".imageTags[] | contains(\"latest\") | not"
    ],
    "identifier": 42746828
  },
  {
    "context": [
      "Is there a way I can concatenate these js's command in just one jq command?",
      "jq 'map({a: .children[1].text, f: .children[0].text})' | \\",
      "jq 'map(select(.a != null))' | \\",
      "jq 'map(select(.f != null))' | \\",
      "jq 'map([.a, [.f,(.f | length)]])' | \\",
      "jq -c '.[]'",
      "`jq -c '.[]\n| {a: .children[1].text, f: .children[0].text}\n| select(.a != null)\n| select(.f != null)\n| [.a, [.f,(.f | length)]]'`"
    ],
    "utterance": "Produce a list of arrays containing the text of the second and first child elements and the length of the first child's text from each element where both texts are not null, in one command.",
    "expressions": [
      ".[] | {a: .children[1].text, f: .children[0].text} | select(.a != null) | select(.f != null) | [.a, [.f, (.f | length)]]"
    ],
    "identifier": 42717586
  },
  {
    "context": [
      "how could i get the following output? (here the key is each element of the serials array, and the value is the key of the sample json):",
      "reduce to_entries[] as $kv ({};\n  reduce $kv.value.serials[] as $s (.;\n    . + {($s): (.[$s] + [$kv|.key]) } ) )",
      "[ to_entries[]\n  | .key as $k\n  | reduce .value.serials[] as $v ({}; .[$v] += [$k])\n] | add",
      "map_values(.serials) | reduce to_entries[] as $e ({};\n    .[$e.value[]] += [$e.key]\n)"
    ],
    "utterance": "Transform the data so that each serial becomes a key whose value is a list of the original product ids containing it.",
    "expressions": [
      "reduce to_entries[] as $kv ({};\n  reduce $kv.value.serials[] as $s (.;\n    . + {($s): (.[$s] + [$kv|.key]) } ) )",
      "[ to_entries[]\n  | .key as $k\n  | reduce .value.serials[] as $v ({}; .[$v] += [$k])\n] | add",
      "map_values(.serials) | reduce to_entries[] as $e ({};\n    .[$e.value[]] += [$e.key]\n)"
    ],
    "data": [
      {
        "input": {
          "prodid_876006": {
            "serid": [
              {
                "seridone": "3265874"
              },
              {
                "seridtwo": "21458915"
              }
            ],
            "serials": [
              "028915"
            ]
          },
          "prodid_980": {
            "serid": [
              {
                "seridone": "32743214"
              },
              {
                "seridtwo": "5469872"
              }
            ],
            "serials": [
              "192147",
              "1632589"
            ]
          }
        },
        "output": {
          "028915": [
            "prodid_876006"
          ],
          "192147": [
            "prodid_980"
          ],
          "1632589": [
            "prodid_980"
          ]
        }
      }
    ],
    "identifier": 42766399
  },
  {
    "context": [
      "Given\r\n\r\n    [\r\n      {\"json1\": \"http://example.com/remote1.json\"},\r\n      {\"json2\": \"http://example.com/remote2.json\"}\r\n    ]\r\n\r\nwith `remote1.json` and `remote2.json` containing `[1]` and `[2]` respectively\r\n\r\nHow to turn it into\r\n\r\n    [{\"json1\": [1], \"json2\": [2]}]\r\n\r\nusing jq? I think other CLI tools like bash and curl are needed. But I have no idea how to merge the responses back.",
      "Output is properly:\r\n\r\n    [{\"json1\":[1]},{\"json2\":[2]}]"
    ],
    "utterance": "Replace all object values that are URL strings with the contents fetched from those URLs, so that keys originally pointing to remote1.json and remote2.json now have values [1] and [2] respectively.",
    "expressions": [
      "walk(\n  if type == \"object\" then\n    if .[\"json1\"] then .[\"json1\"] = [1] else . end |\n    if .[\"json2\"] then .[\"json2\"] = [2] else . end\n  else . end\n)"
    ],
    "data": [
      {
        "input": [
          {
            "json1": "http://example.com/remote1.json"
          },
          {
            "json2": "http://example.com/remote2.json"
          }
        ],
        "output": [
          {
            "json1": [
              1
            ]
          },
          {
            "json2": [
              2
            ]
          }
        ]
      }
    ],
    "identifier": 42719319
  },
  {
    "context": [
      "for each json object, extract the prodid_ info, and the serials array, and make a new json file, with the following format:",
      "{    \r\n    \"prodid_876006\" : [\"028915\"],\r\n    \"prodid_980\" : [\"192147\",\"1632589\"]\r\n    }",
      "For question #1, simply replace the value by the serials property:",
      "with_entries(.value|=.serials)",
      "how could i also get in another json the following output? (here the key is each element of the serials array, and the value is the key of the first sample json):",
      "{    \r\n    \"028915\" : [\"prodid_876006\"],\r\n    \"192147\" : [\"prodid_980\"],\r\n    \"1632589\" : [\"prodid_980\"]\r\n    }",
      "with_entries({key:.value.serials[], value:[.key]})"
    ],
    "utterance": "Produce an object where each element in every serials array is a key and its value is an array containing the original object key.",
    "expressions": [
      "with_entries({key:.value.serials[], value:[.key]})"
    ],
    "data": [
      {
        "input": {
          "prodid_876006": {
            "serid": [
              {
                "seridone": "3265874"
              },
              {
                "seridtwo": "21458915"
              }
            ],
            "serials": [
              "028915"
            ]
          },
          "prodid_980": {
            "serid": [
              {
                "seridone": "32743214"
              },
              {
                "seridtwo": "5469872"
              }
            ],
            "serials": [
              "192147",
              "1632589"
            ]
          }
        },
        "output": {
          "028915": [
            "prodid_876006"
          ],
          "192147": [
            "prodid_980"
          ],
          "1632589": [
            "prodid_980"
          ]
        }
      }
    ],
    "identifier": 42762941
  },
  {
    "context": [
      "I\u2019m trying to extract the first **username** value under the `\"accounts\"` field.",
      "there are multiple entries (\"someone\" and \"someoneelse\") and i only need the first key\u2019s value in the list (\"JQ_Newb\" or \"GOD\", depending on how the JSON is parsed).",
      "If your jq has `first/1`:\r\n\r\n    first(.accounts[] | .username)",
      "Otherwise you might like to consider:\r\n\r\n    [.accounts[] | .username][0]"
    ],
    "utterance": "Extract the first username value from the accounts field when there are multiple accounts.",
    "expressions": [
      "first(.accounts[] | .username)",
      "[.accounts[] | .username][0]"
    ],
    "data": [
      {
        "input": {
          "accounts": {
            "someone": {
              "username": "JQ_Newb",
              "info": "stackoverflow"
            },
            "someoneelse": {
              "username": "GOD",
              "info": "heaven"
            }
          }
        },
        "output": "JQ_Newb"
      }
    ],
    "identifier": 42768870
  },
  {
    "context": [
      "In order to make the output human readable, I have to pipe it into jq like:\r\n\r\n    $ ./foo | jq .",
      "I'm writing a go program (let's call it foo) that outputs JSON on the Standard Out.",
      "Is there a way to achieve the same result using a jq wrapper that is open sourced? I tried finding some but they are usually wrapping the functionality for filtering JSON input not prettifying JSON output."
    ],
    "utterance": "Pretty-print objects streamed on separate lines so that each object's fields appear indented and formatted for human readability.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": [
          {
            "id": "uuid1",
            "name": "John Smith"
          },
          {
            "id": "uuid2",
            "name": "Jane Smith"
          }
        ],
        "output": [
          "{\n  \"id\": \"uuid1\",\n  \"name\": \"John Smith\"\n}",
          "{\n  \"id\": \"uuid2\",\n  \"name\": \"Jane Smith\"\n}"
        ]
      }
    ],
    "identifier": 42788045
  },
  {
    "context": [
      "i need to transform the following",
      "input:   \r\n \r\n\r\n    {\r\n          &quot;id-952&quot;: [\r\n            &quot;serial-8915&quot;\r\n          ],\r\n          &quot;id-546&quot;: [\r\n            &quot;serial-5747&quot;,\r\n            &quot;serial-8735&quot;\r\n          ]\r\n\r\nDesired output:\r\n\r\n    {\r\n    &quot;serial-8915&quot;: [&quot;id-952&quot;],\r\n    &quot;serial-5747&quot;: [&quot;id-546&quot;],\r\n    serial-8735&quot;: [&quot;id-546&quot;]\r\n    }",
      "A very concise solution using [`with_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries), swapping keys and values:",
      "with_entries({key:.value[], value:[.key]})",
      "Here is another solution which uses **add**",
      ". as $d | [ keys[] | {($d[.][]): [.]} ] | add"
    ],
    "utterance": "Transform an object mapping IDs to arrays of serials into an object mapping each serial to an array containing its corresponding ID.",
    "expressions": [
      "with_entries({key:.value[], value:[.key]})",
      ". as $d | [ keys[] | {($d[.][]): [.]} ] | add",
      ". as $d | keys | map( {($d[.][]):[.]} ) | add"
    ],
    "data": [
      {
        "input": {
          "id-952": [
            "serial-8915"
          ],
          "id-546": [
            "serial-5747",
            "serial-8735"
          ]
        },
        "output": {
          "serial-8915": [
            "id-952"
          ],
          "serial-5747": [
            "id-546"
          ],
          "serial-8735": [
            "id-546"
          ]
        }
      }
    ],
    "identifier": 42769054
  },
  {
    "context": [
      "I am trying to return the object which for example started in March.",
      "I have tried using \"match\" but it only returns matched string and \"contain\" only returns boolean values.",
      "however not sure how to specify a partial match as I did not see ~= in the docs as I would need to do something like ~= \"2017-03\"",
      "This worked for me:\r\n\r\n    jq 'if .Start >= \"2017-03\" then . else empty end'"
    ],
    "utterance": "Return all objects where the Start field begins with '2017-03'.",
    "expressions": [
      "if .Start >= \"2017-03\" then . else empty end"
    ],
    "data": [
      {
        "input": [
          {
            "Status": "Down",
            "StatusID": "72875529",
            "Start": "2017-03-01 04:26:07",
            "End": "2017-03-01 04:36:40",
            "Additional": "Unexpected StatusCode Detected - StatusCode: undefined",
            "Period": "10 Minutes "
          },
          {
            "Status": "Down",
            "StatusID": "72785390",
            "Start": "2017-02-28 16:24:26",
            "End": "2017-02-28 16:26:01",
            "Period": "1 Minutes "
          }
        ],
        "output": [
          {
            "Status": "Down",
            "StatusID": "72875529",
            "Start": "2017-03-01 04:26:07",
            "End": "2017-03-01 04:36:40",
            "Additional": "Unexpected StatusCode Detected - StatusCode: undefined",
            "Period": "10 Minutes "
          }
        ]
      }
    ],
    "identifier": 42812689
  },
  {
    "context": [
      "I\u0019m trying to get the long number field (see below) and ommit everything else but fail to do so.",
      "The following will extract all key names from `.authenticationDatabase.JQ_Newb.profiles` :",
      "jq -r '.authenticationDatabase.JQ_Newb.profiles | to_entries[] | .key' data.json",
      "You\u0019ve already been given a working solution but here was my answer using `keys`",
      "jq -r '.authenticationDatabase.JQ_Newb.profiles | keys[]' jqnewb.json"
    ],
    "utterance": "Extract the profile ID field from authenticationDatabase.JQ_Newb.profiles.",
    "expressions": [
      ".authenticationDatabase.JQ_Newb.profiles | to_entries[] | .key",
      ".authenticationDatabase.JQ_Newb.profiles | keys[]"
    ],
    "data": [
      {
        "input": {
          "jsonProfile": {
            "version": "1.0",
            "format": 1
          },
          "authenticationDatabase": {
            "JQ_Newb": {
              "username": "JQ_Newb",
              "profiles": {
                "12345678901234567890123456789012": {
                  "displayName": "JQ_Newb"
                }
              }
            }
          }
        },
        "output": "12345678901234567890123456789012"
      }
    ],
    "identifier": 42750089
  },
  {
    "context": [
      "I need to print every instance-name that does not contain key-one. For example the command would return instance-name-5 if applied to the below.",
      "Since you are using jq, it would make sense to apply the filter using jq.  jq 1.5 supports regular expressions, so you could for example include something like: `..... | select(.key | test(\"key-one\") | not)`",
      "If your jq does not include regex support, then consider upgrading, or using `index` or perhaps `contains` (but check the documentation for how to use these appropriately with your version of jq)."
    ],
    "utterance": "Print all instance-name values that do not have any entry with the value key-one.",
    "expressions": [
      "group_by(.[0]) | map(select(all(.[]; .[1] != \"key-one\"))) | .[].0"
    ],
    "data": [
      {
        "input": [
          [
            "instance-name-1",
            "key-one"
          ],
          [
            "instance-name-1",
            "instance-template"
          ],
          [
            "instance-name-1",
            "created-by"
          ],
          [
            "instance-name-2",
            "key-one"
          ],
          [
            "instance-name-2",
            "instance-template"
          ],
          [
            "instance-name-2",
            "created-by"
          ],
          [
            "instance-name-3",
            "key-one"
          ],
          [
            "instance-name-3",
            "key-one"
          ],
          [
            "instance-name-3",
            "instance-template"
          ],
          [
            "instance-name-3",
            "created-by"
          ],
          [
            "instance-name-4",
            "key-one"
          ],
          [
            "instance-name-4",
            "instance-template"
          ],
          [
            "instance-name-4",
            "created-by"
          ],
          [
            "instance-name-5",
            "key-two"
          ],
          [
            "instance-name-5",
            "instance-template"
          ],
          [
            "instance-name-5",
            "created-by"
          ]
        ],
        "output": [
          "instance-name-5"
        ]
      }
    ],
    "identifier": 42716872
  },
  {
    "context": [
      "The task can be accomplished without invoking jq more than once.",
      "jq -s '{orgConfig: {departments: . }}' jsonfiles/*.json",
      "jq -n 'input | .orgConfig.departments += [inputs]' \\",
      "employee.json chemistry.json physics.json math.json"
    ],
    "utterance": "Add multiple department objects to the departments array within orgConfig, using multiple department files as sources and without hardcoding array indices.",
    "expressions": [
      "jq -s '{orgConfig: {departments: . }}' jsonfiles/*.json",
      "jq -n 'input | .orgConfig.departments += [inputs]' employee.json chemistry.json physics.json math.json"
    ],
    "data": [
      {
        "input": {
          "orgConfig": {
            "departments": []
          }
        },
        "output": {
          "orgConfig": {
            "departments": [
              {
                "name": "physics",
                "id": "1234",
                "head": "abcd"
              },
              {
                "name": "chemistry",
                "id": "3421",
                "head": "xyz"
              },
              {
                "name": "Maths",
                "id": "4634",
                "head": "jklm"
              }
            ]
          }
        }
      }
    ],
    "identifier": 42877900
  },
  {
    "context": [
      "We would like the following output:\r\n    \r\n\t{\r\n\t    \"desiredvalueone\": [{\r\n\t        \"name_A\": \"logfile_one\"\r\n\t    }],\r\n\t    \"desiredvaluetwo\": [{\r\n\t        \"name_A\": \"logfile_one\",\r\n\t        \"name_B\": \"logfile_two\"\r\n\t    }],\r\n\t    ...\r\n\t}\r\n",
      "The key to the solution given here is the helper function for combining a stream of JSON objects:\r\n \r\n    # Combine a stream of JSON objects into a single object\r\n    # by converting the value v to [v] at each\r\n    # key, and then appending the arrays at each key.\r\n    def combine(s):\r\n      reduce s as $o ({};\r\n        reduce ($o|keys[]) as $k (.; .[$k] += [$o[$k]]  ) );\r\n",
      "combine( to_entries[]\r\n       | .key as $k\r\n       | .value\r\n       | to_entries[]\r\n       | select( .key | startswith(\"logfile_\"))\r\n       | .key as $innerkey\r\n       | .value[]\r\n       | to_entries[]\r\n       | { (.value): { ($k): $innerkey }}\r\n     ) | map_values(add)",
      "[\r\n      . as $d\r\n    | [\r\n          keys[] as $k                           # e.g \"name_A\"...\r\n        | ($d[$k] | keys[]\r\n           | select($d[$k][.][0]|type==\"object\")\r\n           ) as $k2                              # k2:  \"logfile_one\"\r\n        | $d[$k][$k2][] as $v                    # v:  {\"issue_desc\":\"desiredvalueone\"},\r\n        | ($v|keys[]) as $k3                     # k3: \"issue_desc\"\r\n        | {v:$v[$k3], k:$k, k2:$k2}              # {\"v\":\"desiredvalueone\",\"k\":\"name_A\",\"k2\":\"logfile_one\"}\r\n      ]\r\n    | group_by(.v)[]\r\n    | reduce .[] as $t (\r\n        {}\r\n      ; .[$t.v] += {($t.k): $t.k2}\r\n      )\r\n    ]\r\n    | add\r\n    | map_values([.])"
    ],
    "utterance": "Transform nested objects so that issue descriptions and times are mapped to objects indicating which source name and logfile they originated from, grouped by value as keys.",
    "expressions": [
      "def combine(s): reduce s as $o ({}; reduce ($o|keys[]) as $k (.; .[$k] += [$o[$k]]  ) ); combine( to_entries[] | .key as $k | .value | to_entries[] | select( .key | startswith(\"logfile_\")) | .key as $innerkey | .value[] | to_entries[] | { (.value): { ($k): $innerkey }} ) | map_values(add)",
      "[ . as $d | [ keys[] as $k | ($d[$k] | keys[] | select($d[$k][.][0]|type==\"object\")) as $k2 | $d[$k][$k2][] as $v | ($v|keys[]) as $k3 | {v:$v[$k3], k:$k, k2:$k2} ] | group_by(.v)[] | reduce .[] as $t ( {}; .[$t.v] += {($t.k): $t.k2} ) ] | add | map_values([.])"
    ],
    "data": [
      {
        "input": {
          "name_A": {
            "logfile_one": [
              {
                "issue_desc": "desiredvalueone"
              },
              {
                "issuetime": "desiredvaluetwo"
              }
            ],
            "output": [
              "46312"
            ]
          },
          "name_B": {
            "logfile_two": [
              {
                "issue_desc": "desiredvaluethirtyfour"
              },
              {
                "issuetime": "desiredvaluetwo"
              }
            ],
            "output": [
              "1",
              "2"
            ]
          }
        },
        "output": {
          "desiredvalueone": [
            {
              "name_A": "logfile_one"
            }
          ],
          "desiredvaluethirtyfour": [
            {
              "name_B": "logfile_two"
            }
          ],
          "desiredvaluetwo": [
            {
              "name_A": "logfile_one",
              "name_B": "logfile_two"
            }
          ]
        }
      }
    ],
    "identifier": 42785677
  },
  {
    "context": [
      "I want to filter out \"store\" field in all keys to get an output like ...",
      "Use `del` and `recurse` together.",
      "jq 'del(recurse|.store?)' foo.json",
      "You can also the short `..` for `recurse` with no arguments:",
      "jq 'del(..|.store?)' foo.json",
      "If you only want to remove the \"store\" key when it occurs at the second level, then consider:",
      "map_values( del(.store) )"
    ],
    "utterance": "Remove all occurrences of the 'store' field at any nesting level from the data structure.",
    "expressions": [
      "del(recurse|.store?)",
      "del(..|.store?)",
      "map_values( del(.store) )"
    ],
    "data": [
      {
        "input": {
          "talk": {
            "docs": {
              "count": 22038185,
              "deleted": 626193
            },
            "store": {
              "size_in_bytes": 6885993125,
              "throttle_time_in_millis": 1836569
            }
          },
          "list": {
            "docs": {
              "count": 22038185,
              "deleted": 626193
            },
            "store": {
              "size_in_bytes": 6885993125,
              "throttle_time_in_millis": 1836569
            }
          }
        },
        "output": {
          "talk": {
            "docs": {
              "count": 22038185,
              "deleted": 626193
            }
          },
          "list": {
            "docs": {
              "count": 22038185,
              "deleted": 626193
            }
          }
        }
      }
    ],
    "identifier": 42908338
  },
  {
    "context": [
      "How to convert a simpe `ps aux` to Json?",
      "ps aux | awk \u2035...Just adjust columns which you need from ps aux output.",
      "`jq` can read non-JSON input. You'll want to pre-process the input with `awk` first:\n\n    ps aux |\n      awk -v OFS=, '{print $1, $2}' | \n      jq -R 'split(\",\") | {user: .[0], pid: .[1]}'\n\nIf you want an array instead of a sequence of objects, pipe the output through jq --slurp 'add'.",
      "Here's an only-jq solution based on tokenization.\n\nTokenization can be done using:\n\ndef tokens:\n  def trim: sub(\"^ +\";\"\") |  sub(\" +$\";\"\");\n  trim | splits(\" +\");\n\nFor illustration and brevity, let's consider only the first 10 tokens:\n\n    [tokens] | .[0:9]\n\nInvocation:\n\n    $ ps aux | jq -c -R  -f tokens.jq \n\nOr as a one-liner, you could get away with:\n\n    $  ps aux | jq -cR '[splits(\" +\")] | .[0:9]'",
      "Dumps the fields specified by the -o flag as an array of PID objects:\n\nps ax -o \"stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,wchan,sz,pcpu,command\" \\\n\t| jq -sRr ' sub(\"\\n$\";\"\") | split(\"\\n\") | ([.[0]|splits(\" +\")]) as $header | .[1:] | [.[] | [. as $x | range($header|length) | {\"key\": $header[.], \"value\": (if .==($header|length-1) then ([$x|splits(\" +\")][.:]|join(\" \")|tojson|.[1:length-1]) else ([$x|splits(\" +\")][.]) end) } ] | from_entries]'"
    ],
    "utterance": "Convert the output of 'ps aux' to a list of objects with field names as keys, such as user, pid, cpu, and more, without using Perl or Python.",
    "expressions": [
      "ps aux | awk -v OFS=, '{print $1, $2}' | jq -R 'split(\",\") | {user: .[0], pid: .[1]}'",
      "ps aux | jq -cR '[splits(\" +\")] | .[0:9]'",
      "ps ax -o \"stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,wchan,sz,pcpu,command\" | jq -sRr 'sub(\"\\n$\";\"\") | split(\"\\n\") | ([.[0]|splits(\" +\")]) as $header | .[1:] | [.[] | [. as $x | range($header|length) | {\"key\": $header[.], \"value\": (if .==($header|length-1) then ([$x|splits(\" +\")][.:]|join(\" \")|tojson|.[1:length-1]) else ([$x|splits(\" +\")][.]) end) } ] | from_entries]'"
    ],
    "identifier": 42855490
  },
  {
    "context": [
      "I'm attempting to use jq to transform it into a correct format.",
      "my goal has been to change all geometry items of type \"Path\" into a \"LineString\", and strip out the extra coordinates in these items into a \"properties\" object (on the geometry item) to preserve the data.",
      "For each feature, I'm trying to check if geometry.type == \"Path\", and if so, strip the first item from each coordinate (I don't need it), and then move all but the last two items from the coordinate into a object in a properties.curves array, noting the position within the \"coordinates\" array, and the extra data.",
      "Here is a variant of your jq filter that produces the results shown below:",
      "geometry: {\n           \t        type: (if .geometry.type == \"Path\" then \"LineString\"\n    \t\t               else .geometry.type\n                           end)\n                }\n            }\n        ]\n    }"
    ],
    "utterance": "Transform each feature with geometry type equal to \"Path\" by changing its geometry type to \"LineString\", stripping the first item from each coordinate, and moving all but the last two items from each coordinate into a 'properties.curves' array within the geometry, recording their positions and values; for features with other geometry types, copy the geometry unchanged.",
    "expressions": [
      "  {\n    type: .type,\n    features: [\n      .features[] | {\n        type: .type,\n        properties: (\n          .properties + {id: .id} \n        ),\n        geometry: (\n          if .geometry.type == \"Path\" then\n            {\n              type: \"LineString\",\n              properties: {\n                curves: (\n                  [\n                    .geometry.coordinates\n                    | to_entries[]\n                    | select((.value|length) > 4)\n                    | {\n                        coordinate_position: .key,\n                        control_points: (.value[1: -2])\n                      }\n                  ]\n                )\n              },\n              coordinates: (\n                [\n                  .geometry.coordinates[]\n                  | .[-2:]                         # take the last two items only\n                ]\n              )\n            }\n          else\n            .geometry\n          end\n        )\n      }\n    ]\n  }"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "id": 16683828,
              "properties": {
                "facility": "hallway"
              },
              "type": "Feature",
              "geometry": {
                "type": "Path",
                "coordinates": [
                  [
                    0,
                    379.64,
                    289.412
                  ],
                  [
                    3,
                    379.629,
                    289.768,
                    379.346,
                    290.059,
                    378.986,
                    290.066
                  ],
                  [
                    1,
                    373.156,
                    290.066
                  ],
                  [
                    1,
                    373.156,
                    298.5
                  ],
                  [
                    1,
                    373.156,
                    299.469
                  ],
                  [
                    4
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "facility": "hallway",
                "id": 16683828
              },
              "geometry": {
                "type": "LineString",
                "properties": {
                  "curves": [
                    {
                      "coordinate_position": 1,
                      "control_points": [
                        379.629,
                        289.768,
                        379.346,
                        290.059
                      ]
                    }
                  ]
                },
                "coordinates": [
                  [
                    379.64,
                    289.412
                  ],
                  [
                    378.986,
                    290.066
                  ],
                  [
                    373.156,
                    290.066
                  ],
                  [
                    373.156,
                    298.5
                  ],
                  [
                    373.156,
                    299.469
                  ]
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 42813005
  },
  {
    "context": [
      "when I use the command: \n\n    ids=`cat $myfilename | jq -r \"[.data[].id]\"`",
      "and return like this:\n\n    [\n      \"PC_PACX_0017\",\n      \"GS_ZGRS_0001\",\n      \"PC_PACX_0018\",\n      \"GS_ZGRS_0002\",\n      \"AB_HXJK_0002\",\n      \"AB_HXJK_0001\",\n      \"TK_TKZX_0011\",\n      \"TL_TBAL_0002\",\n      \"TL_TBAL_0001\",\n      \"TS_TKRS_0001\",\n      \"TS_TKRS_0002\",\n      \"TS_TKRS_0003\"\n    ]",
      "but it can't be seen as a array, it's length only be 1.How can I use this result?",
      "An array is distinct from a multi-line string. ... changing your `jq` call to\n\n    jq -r '[.data[].id]|.[]'  # Could be simplified to '.data[].id'",
      "use `readArray` (`bash` 4 or later) to populate a proper array.\n\n    readArray -t ids < <(jq -r '[.data[].id]|.[]' \"$myfilename\")"
    ],
    "utterance": "Return each value of all id fields under data as separate lines for use in a Bash array.",
    "expressions": [
      ".data[].id",
      "[.data[].id] | .[]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "PC_PACX_0017"
            },
            {
              "id": "GS_ZGRS_0001"
            },
            {
              "id": "PC_PACX_0018"
            },
            {
              "id": "GS_ZGRS_0002"
            },
            {
              "id": "AB_HXJK_0002"
            },
            {
              "id": "AB_HXJK_0001"
            },
            {
              "id": "TK_TKZX_0011"
            },
            {
              "id": "TL_TBAL_0002"
            },
            {
              "id": "TL_TBAL_0001"
            },
            {
              "id": "TS_TKRS_0001"
            },
            {
              "id": "TS_TKRS_0002"
            },
            {
              "id": "TS_TKRS_0003"
            }
          ]
        },
        "output": [
          "PC_PACX_0017",
          "GS_ZGRS_0001",
          "PC_PACX_0018",
          "GS_ZGRS_0002",
          "AB_HXJK_0002",
          "AB_HXJK_0001",
          "TK_TKZX_0011",
          "TL_TBAL_0002",
          "TL_TBAL_0001",
          "TS_TKRS_0001",
          "TS_TKRS_0002",
          "TS_TKRS_0003"
        ]
      }
    ],
    "identifier": 42926472
  },
  {
    "context": [
      "I have an array like this:\r\n\r\n    [\r\n    {\"price\": 10},\r\n    {\"price\": 20},\r\n    {\"price\": 30}\r\n    ]",
      "I want to go over each price item and set it to be negative.",
      "If i do something like this:\r\n\r\n    .[].price = .[].price * -1\r\n\r\nI'll get:\r\n\r\n    [\r\n      {\r\n        \"price\": -10\r\n      },\r\n      {\r\n        \"price\": -10\r\n      },\r\n      {\r\n        \"price\": -10\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        \"price\": -20\r\n      },\r\n      {\r\n        \"price\": -20\r\n      },\r\n      {\r\n        \"price\": -20\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        \"price\": -30\r\n      },\r\n      {\r\n        \"price\": -30\r\n      },\r\n      {\r\n        \"price\": -30\r\n      }\r\n    ]\r\n\r\nHow do i do it properly so at the end it will look like this?\r\n\r\n    [\r\n    {\"price\": -10},\r\n    {\"price\": -20},\r\n    {\"price\": -30}\r\n    ]",
      "map( .price |= -1 * . )"
    ],
    "utterance": "For each object in the array, set price to its negative value.",
    "expressions": [
      "map( .price |= -1 * . )"
    ],
    "data": [
      {
        "input": [
          {
            "price": 10
          },
          {
            "price": 20
          },
          {
            "price": 30
          }
        ],
        "output": [
          {
            "price": -10
          },
          {
            "price": -20
          },
          {
            "price": -30
          }
        ]
      }
    ],
    "identifier": 42930165
  },
  {
    "context": [
      "I'm trying to convert the following JSON structure to CSV:",
      "I know how to use the `split()` function to \"explode\" an individual property into three values using the semicolon as a divider - but how do I tell jq I want to split both the `node` and the `adjacency` property in the same pass?",
      "$ jq -r '.[] | [.node, .adjacency] | map (split(\";\")) | flatten | @csv' some.json",
      "| [.node, .adjacency]\n| map (split(\";\"))\n| flatten\n| map(tonumber?//.)\n| @csv"
    ],
    "utterance": "Extract all semicolon-separated values from both the 'node' and 'adjacency' properties of each object and output them as a single CSV line per object.",
    "expressions": [
      ".[] | [.node, .adjacency] | map(split(\";\")) | flatten | @csv",
      ".[] | [.node, .adjacency] | map(split(\";\")) | flatten | map(tonumber?//.) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "node": "hosta;10.0.0.20;37038",
            "adjacency": "hostb;10.0.0.10;4001"
          },
          {
            "node": "hostc;10.0.0.16;52732",
            "adjacency": "hostd;10.0.0.24;4040"
          }
        ],
        "output": [
          "\"hosta\",\"10.0.0.20\",\"37038\",\"hostb\",\"10.0.0.10\",\"4001\"",
          "\"hostc\",\"10.0.0.16\",\"52732\",\"hostd\",\"10.0.0.24\",\"4040\""
        ]
      }
    ],
    "identifier": 42930707
  },
  {
    "context": [
      "And would like to get...\n\n    [\n        {\n            \"myfield1\": \"foo\",\n            \"field1\": 6366987,\n            \"field2\": 5501072 \n        },\n        {\n            \"myfield1\": \"foo\",\n            \"field1\": 123456,\n            \"field2\": 123456 \n        },\n    ]",
      "jq '[.[0]|with_entries(select(.key != \"myfield2\"))+( .myfield2|fromjson)]'",
      "map( { myfield1 } + ( .myfield2 | fromjson ) )",
      "map( del(.myfield2) + ( .myfield2 | fromjson ) )"
    ],
    "utterance": "Flatten objects by extracting fields from a string-encoded dictionary in 'myfield2', merging them with the sibling fields at the same level.",
    "expressions": [
      "map({myfield1} + (.myfield2 | fromjson))",
      "map(del(.myfield2) + (.myfield2 | fromjson))",
      "[.[0]|with_entries(select(.key != \"myfield2\"))+(.myfield2|fromjson)]"
    ],
    "data": [
      {
        "input": [
          {
            "myfield1": "foo",
            "myfield2": "{\"field1\":6366987, \"field2\":5501072}"
          },
          {
            "myfield1": "bar",
            "myfield2": "{\"field1\":123456, \"field2\":123456}"
          }
        ],
        "output": [
          {
            "myfield1": "foo",
            "field1": 6366987,
            "field2": 5501072
          },
          {
            "myfield1": "bar",
            "field1": 123456,
            "field2": 123456
          }
        ]
      }
    ],
    "identifier": 42934070
  },
  {
    "context": [
      "Given a JSON file called `parameters.json` with keypairs like so; (shortened for sharing purposes)\n\n    [\n      {\n        \"ParameterKey\": \"Foo1\",\n        \"ParameterValue\": \"Bar1\"\n      },\n      {\n        \"ParameterKey\": \"Foo2\",  \n        \"ParameterValue\": \"Bar2\"\n      }\n    ]",
      "I want to add another keypair, say\n\n      {\n        \"ParameterKey\": \"Foo3\",\n        \"ParameterValue\": \"Bar3\"\n      }",
      "So I end up with a file like\n\n    [\n      {\n        \"ParameterKey\": \"Foo1\",\n        \"ParameterValue\": \"Bar1\"\n      },\n      {\n        \"ParameterKey\": \"Foo2\",  \n        \"ParameterValue\": \"Bar2\"\n      },\n      {\n        \"ParameterKey\": \"Foo3\",\n        \"ParameterValue\": \"Bar3\"\n      }\n    ]",
      "The idea of using `argjson` is right, but the syntax is as below on `jq-1.5`\n\n    jq --argjson obj '{ \"ParameterKey\": \"Foo3\", \"ParameterValue\": \"Bar3\" }' '. + [$obj]' < json",
      "$ jq 'reduce inputs as $in (.; . + [$in])' parameters.json file*.json | sponge parameters.json"
    ],
    "utterance": "Append an object with ParameterKey 'Foo3' and ParameterValue 'Bar3' to an array of objects in a file.",
    "expressions": [
      "jq --argjson obj '{ \"ParameterKey\": \"Foo3\", \"ParameterValue\": \"Bar3\" }' '. + [$obj]' parameters.json",
      "jq 'reduce inputs as $in (.; . + [$in])' parameters.json file*.json"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "Foo1",
            "ParameterValue": "Bar1"
          },
          {
            "ParameterKey": "Foo2",
            "ParameterValue": "Bar2"
          }
        ],
        "output": [
          {
            "ParameterKey": "Foo1",
            "ParameterValue": "Bar1"
          },
          {
            "ParameterKey": "Foo2",
            "ParameterValue": "Bar2"
          },
          {
            "ParameterKey": "Foo3",
            "ParameterValue": "Bar3"
          }
        ]
      }
    ],
    "identifier": 42817889
  },
  {
    "context": [
      "Example: \r\n\r\n    $ JSON='{\"decimal\":0.00001}'\r\n    $ echo \"$JSON\" | jq .\r\n    {\r\n      \"decimal\": 1e-05\r\n    }",
      "My problem is that I need decimal numbers to store in SQL, with up to six digits after the point.",
      "You can't change `jq`'s behavior -- at present date, [relevant feature requests](https://github.com/stedolan/jq/issues/1192) are still open -- but you *can* reformat your numbers after they've been retrieved.",
      "json='{ \"decimal\":0.00001 }'\ndecimal=$(jq '.decimal' <<<\"$json\")\ndecimal_f=$(awk -v decimal=\"$decimal\" 'BEGIN { printf(\"%f\\n\", decimal) }' </dev/null)\n\necho \"JQ emitted $decimal; reformatted as $decimal_f\""
    ],
    "utterance": "Retrieve a decimal value with up to six digits after the decimal point, ensuring the output is not in scientific notation.",
    "expressions": [
      ".decimal",
      ".decimal | tostring"
    ],
    "data": [
      {
        "input": {
          "decimal": 1e-05
        },
        "output": "0.00001"
      }
    ],
    "identifier": 42956806
  },
  {
    "context": [
      "What I am looking to get is no change to the `AAAA` object, however for each value in `BBBB.VALUES` I want to take the second value from the `old` array and create a new key value say \"new\"",
      "The array is guaranteed to be two elements long, the array does not need to be modified.",
      "You can use `[ keys[] ]` to iterate over the keys under `BBBB.VALUES` :",
      "jq '(.BBBB.VALUES | . [ keys[] ]) |= .+  { new: .old[1] }' data.json",
      ".BBBB.VALUES |= map_values(.new = .old[1])",
      ".BBBB.VALUES |= with_entries( .value.new = .value.old[1] )"
    ],
    "utterance": "For each entry in BBBB.VALUES, add a key new containing the second element of the old array, leaving all other objects unchanged.",
    "expressions": [
      "(.BBBB.VALUES | .[keys[]]) |= .+ { new: .old[1] }",
      ".BBBB.VALUES |= map_values(.new = .old[1])",
      ".BBBB.VALUES |= with_entries(.value.new = .value.old[1])"
    ],
    "data": [
      {
        "input": {
          "AAAA": {
            "VALUES": {
              "val_1": {
                "key": "A_KEY1"
              },
              "val_2": {
                "key": "A_KEY2"
              }
            }
          },
          "BBBB": {
            "VALUES": {
              "val_a": {
                "key": "KEY1",
                "old": [
                  0,
                  1
                ]
              },
              "val_b": {
                "key": "KEY2",
                "old": [
                  2,
                  3
                ]
              }
            }
          }
        },
        "output": {
          "AAAA": {
            "VALUES": {
              "val_1": {
                "key": "A_KEY1"
              },
              "val_2": {
                "key": "A_KEY2"
              }
            }
          },
          "BBBB": {
            "VALUES": {
              "val_a": {
                "key": "KEY1",
                "old": [
                  0,
                  1
                ],
                "new": 1
              },
              "val_b": {
                "key": "KEY2",
                "old": [
                  2,
                  3
                ],
                "new": 3
              }
            }
          }
        }
      }
    ],
    "identifier": 42938923
  },
  {
    "context": [
      "I wanted to change the JSON attribute from \"environmentName\" to \"prod\". Below is the output i am expecting",
      "jq '.envConfig |= with_entries(.key |= sub(\"^environmentName$\"; \"prod\"))'",
      "jq '(.envConfig |= (. + {\"prod\":.environmentName}|del(.environmentName)))' foo.json"
    ],
    "utterance": "Rename the key 'environmentName' under 'envConfig' to 'prod', preserving the associated value and all other keys.",
    "expressions": [
      ".envConfig |= with_entries(.key |= sub(\"^environmentName$\"; \"prod\"))",
      "(.envConfig |= (. + {\"prod\":.environmentName}|del(.environmentName)))"
    ],
    "data": [
      {
        "input": {
          "envConfig": {
            "environmentName": {
              "versions": [
                {
                  "name": "version1",
                  "value": "Dev"
                },
                {
                  "name": "version2",
                  "host": "qa"
                }
              ],
              "userRoles": [
                {
                  "name": "Roles",
                  "entry": [
                    {
                      "name": "employees",
                      "value": "rwx"
                    },
                    {
                      "name": "customers",
                      "value": "rx"
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": {
          "envConfig": {
            "prod": {
              "versions": [
                {
                  "name": "version1",
                  "value": "Dev"
                },
                {
                  "name": "version2",
                  "host": "qa"
                }
              ],
              "userRoles": [
                {
                  "name": "Roles",
                  "entry": [
                    {
                      "name": "employees",
                      "value": "rwx"
                    },
                    {
                      "name": "customers",
                      "value": "rx"
                    }
                  ]
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 42969020
  },
  {
    "context": [
      "I have following json:",
      "I'm trying to create another json that will consider the non-empty/not null `.Name` as priority otherwise get `.FullName` regardless if it's empty or null, the final json would look like following:",
      "jq '[.Detail.Response[] | {id: .ID, name: [.Name, .FullName] | join(\"\") }]'",
      "This should get you on your way:",
      ".Detail.Response[]\n| { id: .ID, Name: (if .Name != \"\" then .Name else .FullName end) }",
      "I figure out a way to do it using `map` and `select`.",
      "jq '[.Detail.Response[] | {id: .ID, name: [.Name, .FullName] | map(select(length > 0)) | first }]'"
    ],
    "utterance": "Return an array of objects with id and name, where name uses .Name if it is not empty or null, otherwise uses .FullName.",
    "expressions": [
      ".Detail.Response[] | {id: .ID, name: (if .Name != \"\" and .Name != null then .Name else .FullName end)}",
      "[.Detail.Response[] | {id: .ID, name: [.Name, .FullName] | map(select(length > 0)) | first}]"
    ],
    "data": [
      {
        "input": {
          "Detail": {
            "Response": [
              {
                "ID": "8000000D-1483989576",
                "Name": "",
                "FullName": "FullName 1"
              },
              {
                "ID": "8000000C-1483985849",
                "Name": "Name 1"
              },
              {
                "ID": "80000006-1481277410",
                "Name": "Name 2",
                "FullName": "FullName 2"
              },
              {
                "ID": "8000000B-1481537384",
                "Name": "Name 3"
              }
            ]
          }
        },
        "output": [
          {
            "id": "8000000D-1483989576",
            "name": "FullName 1"
          },
          {
            "id": "8000000C-1483985849",
            "name": "Name 1"
          },
          {
            "id": "80000006-1481277410",
            "name": "Name 2"
          },
          {
            "id": "8000000B-1481537384",
            "name": "Name 3"
          }
        ]
      }
    ],
    "identifier": 42938980
  },
  {
    "context": [
      "`cat my.json | jq .` pretty-prints the given JSON, but expands every field on a separate line.",
      "But what if some of the fields are repetitive, such as a list of points? How can fields that match a pattern be formatted on a single line with `--compact-output`?",
      "For example, format \"coords\" and \"list\" fields below on a single line:",
      "A constrained-width JSON pretty-printer could be written in jq itself.",
      "Here is a pretty-printer which illustrates how this could be done, though in its present incarnation, it is of limited usefulness.",
      "def ppArray(indent; incr; width): ...",
      "[range(0;16)] | (ppArray(0; 2; 10)), \"::\", ([{a:1}, {b:2}, {c:3}]  | ppArray(0; 2; 10)), \"::\", (.[2]=[range(0;10)]) | ppArray(0; 2; 10)"
    ],
    "utterance": "Format fields named \"coords\" and \"list\" so their array values appear on a single line, while other fields are pretty-printed with standard indentation.",
    "expressions": [
      "def ppArray(indent; incr; width):\n  def ppArray_(incr_; width_):\n    tostring as $tostring\n    | if $tostring|length <= (width_ - incr_) then [$tostring]\n      else reduce .[] as $i\n        ([];\n         ($i|tostring) as $is\n          | if length == 0 then [ $is ]\n            else .[-1] as $s\n            | ($s|length) as $n\n            | ($is|length) as $isl\n            | if $n + $isl <= (width_ - incr_)\n               then .[-1] = ($s + \", \" + $is)\n              elif ($i|type) == \"array\"\n               then (.[-1]+=\", \") + [ $i | ppArray(0; incr_; width_ - incr_) ]\n              else  (.[-1]+=\", \") + [ $is ]\n              end \n            end )\n      end;\n  (\" \" * indent) as $indentation\n  | if type == \"array\"\n    then ppArray_(incr; width - indent)\n         | $indentation + \"[\",\n         (.[] | ($indentation + \"  \" + . )),\n         $indentation + \"]\"\n  else $indentation + tostring\n  end\n;\n\n# To pretty-print with special handling for \"coords\" and \"list\":\ndef special_pp:\n  walk(\n    if (type == \"object\")\n    then with_entries(\n      if (.key == \"coords\" or .key == \"list\") and (.value | type == \"array\")\n      then .value |= (ppArray(0; 2; 100) | join(\" \"))\n      else .\n      end )\n    else .\n    end\n  );\n\n. | special_pp"
    ],
    "data": [
      {
        "input": [
          {
            "field1": {
              "a": "",
              "b": "",
              "list": [
                {
                  "name": "x",
                  "score": 1,
                  "rect": {
                    "x": 156,
                    "y": 245,
                    "w": 35,
                    "h": 45
                  }
                }
              ]
            },
            "field2": 2,
            "coords": [
              {
                "x": 100,
                "y": 400
              },
              {
                "x": 100,
                "y": 0
              }
            ]
          }
        ],
        "output": [
          {
            "field1": {
              "a": "",
              "b": "",
              "list": "[{\"name\":\"x\",\"score\":1,\"rect\":{\"x\":156,\"y\":245,\"w\":35,\"h\":45}}]"
            },
            "field2": 2,
            "coords": "[{\"x\":100,\"y\":400},{\"x\":100,\"y\":0}]"
          }
        ]
      }
    ],
    "identifier": 42729731
  },
  {
    "context": [
      "How to get the \"Keys\" where the \"Category\" only with \"Shopping\"?",
      "Use the `to_entries` function as in:",
      "jq -r 'to_entries[] | select(.value.Category | index(\"Shopping\") != null) | .key'",
      "In this particular case, `to_entries` and its overhead can be avoided while still yielding a concise and clear solution:",
      "keys[] as $k | select( .[$k].Category | index(\"Shopping\") != null) | $k"
    ],
    "utterance": "List all top-level keys whose Category array contains Shopping.",
    "expressions": [
      "to_entries[] | select(.value.Category | index(\"Shopping\") != null) | .key",
      "keys[] as $k | select( .[$k].Category | index(\"Shopping\") != null) | $k"
    ],
    "data": [
      {
        "input": {
          "bbc.com": {
            "Reputation": "2.1",
            "Rank": "448",
            "Category": [
              "News"
            ]
          },
          "amazon.com": {
            "Reputation": "2.1",
            "Rank": "448",
            "Category": [
              "Shopping"
            ]
          }
        },
        "output": [
          "amazon.com"
        ]
      }
    ],
    "identifier": 42969486
  },
  {
    "context": [
      "How do I use jq within the shell script to output the Keys and values in the _source field (nothing else) as a CSV?",
      "jq -r '.hits.hits[]._source | to_entries | .[] | [.key, .value] | @csv'",
      "...with output:",
      "\"customer_app_version\",\"el7.20150513\"",
      "\"customer_num_apps\",3",
      "\"app_memory_capacity_bytes\",405248409600",
      "\"customer_name\",\"Timbuktu Inc\"",
      "\"app_disk_size_bytes\",25117047875604",
      "\"customer_app_version\",\"el4.20150513\"",
      "\"customer_num_apps\",34",
      "\"app_memory_capacity_bytes\",58923439600",
      "\"customer_name\",\"Bunnies Inc\"",
      "\"app_disk_size_bytes\",36517984275604"
    ],
    "utterance": "Output the keys and values from the _source field of each hit as CSV rows, showing only those pairs and nothing else.",
    "expressions": [
      ".hits.hits[]._source | to_entries | .[] | [.key, .value] | @csv"
    ],
    "data": [
      {
        "input": {
          "took": 8,
          "timed_out": false,
          "_shards": {
            "total": 5,
            "successful": 5,
            "failed": 0
          },
          "hits": {
            "total": 6171,
            "max_score": 1.8510876,
            "hits": [
              {
                "_index": "data_latest_v1",
                "_type": "customer",
                "_id": "0003245-4844-9015-1z2e-d4ae5234rd56",
                "_score": 1.8510876,
                "_source": {
                  "customer_app_version": "el7.20150513",
                  "customer_num_apps": 3,
                  "app_memory_capacity_bytes": 405248409600,
                  "customer_name": "Timbuktu Inc",
                  "app_disk_size_bytes": 25117047875604
                }
              },
              {
                "_index": "data_latest_v1",
                "_type": "customer",
                "_id": "0003245-4844-9015-1z2e-d4ae5234rd56",
                "_score": 1.8510876,
                "_source": {
                  "customer_app_version": "el4.20150513",
                  "customer_num_apps": 34,
                  "app_memory_capacity_bytes": 58923439600,
                  "customer_name": "Bunnies Inc",
                  "app_disk_size_bytes": 36517984275604
                }
              }
            ]
          }
        },
        "output": [
          "\"customer_app_version\",\"el7.20150513\"",
          "\"customer_num_apps\",3",
          "\"app_memory_capacity_bytes\",405248409600",
          "\"customer_name\",\"Timbuktu Inc\"",
          "\"app_disk_size_bytes\",25117047875604",
          "\"customer_app_version\",\"el4.20150513\"",
          "\"customer_num_apps\",34",
          "\"app_memory_capacity_bytes\",58923439600",
          "\"customer_name\",\"Bunnies Inc\"",
          "\"app_disk_size_bytes\",36517984275604"
        ]
      }
    ],
    "identifier": 42846102
  },
  {
    "context": [
      "I am looking for a way to keep only those objects that meet the following (pseudo-jq) condition:",
      "single_json[key] IN List",
      "where List is predefined list of values (around 50k) - stored in another file (lets say one value per line)",
      "You can read in your list of predefined values using one of the command-line options, e.g.",
      "jq --argfile list FILEPATH ...",
      "To check whether a JSON value is in an array, you could use `index/1`, e.g.",
      "def check: . as $in | $list | index($in);"
    ],
    "utterance": "Filter objects keeping only those where the value of a specific key exists in a large predefined list of values loaded from an external file.",
    "expressions": [
      "map(select(.key | IN($list[])))"
    ],
    "identifier": 43089326
  },
  {
    "context": [
      "I want to replace `output` field in `result.json` with whole file `output.json` as",
      "You can use `--argfile` to process multiple files :",
      "jq --argfile f1 result.json --argfile f2 output.json -n '$f1 | .output = $f2'",
      "Basically the same as Bertrand Martel's answer, but using a different (and shorter) approach to reading the two files.",
      "jq -n 'input | .output = input' result.json output.json"
    ],
    "utterance": "Replace the output property of the first file with the entire contents of the second file.",
    "expressions": [
      "jq --argfile f1 result.json --argfile f2 output.json -n '$f1 | .output = $f2'",
      "jq -n 'input | .output = input' result.json output.json"
    ],
    "data": [
      {
        "input": {
          "result.json": {
            "Msg": "This is output",
            "output": {}
          },
          "output.json": {
            "type": "string",
            "value": "result is here"
          }
        },
        "output": {
          "Msg": "This is output",
          "output": {
            "type": "string",
            "value": "result is here"
          }
        }
      }
    ],
    "identifier": 43057955
  },
  {
    "context": [
      "Assume you have a json file called `emails.json` that looks like this;",
      "[ { \"ParameterKey\": \"foo1\", \"ParameterValue\": \"bar1\" }, { \"ParameterKey\": \"foo2\", \"ParameterValue\": \"bar2\" } ]",
      "If I run my bash script (let's call it `script.sh`) using the argument foo1, I want to have bar1 assigned to a variable called `emailAdd`. Likewise, if I use the argument foo2, I want bar2 assigned.",
      "emailAdd=$(jq --arg email \"$EMAIL\" '.[] | select(.ParameterKey==\"$email\") | .ParameterValue' < emails.json)",
      "You probably also want to use the `-r` option so that the output is `bar1`, rather than `\"bar1\"`.",
      "emailAdd=$(jq -r --arg email \"$EMAIL\" '.[] | select(.ParameterKey==$email) | .ParameterValue' < emails.json)"
    ],
    "utterance": "Retrieve the ParameterValue for the object where ParameterKey equals a specified value, such as foo1 or foo2.",
    "expressions": [
      ".[] | select(.ParameterKey==$email) | .ParameterValue",
      "-r --arg email \"$EMAIL\" '.[] | select(.ParameterKey==$email) | .ParameterValue'"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "foo1",
            "ParameterValue": "bar1"
          },
          {
            "ParameterKey": "foo2",
            "ParameterValue": "bar2"
          }
        ],
        "output": "bar1"
      }
    ],
    "identifier": 43098269
  },
  {
    "context": [
      "I want to return the value for `Valid` where the `ItemName` equals `Item_2`. How can I do this?",
      ".[] | .Item[] | select( .ItemName == \"Item_2\" ) | .Valid"
    ],
    "utterance": "Return the value of Valid for the object where ItemName equals Item_2.",
    "expressions": [
      ".[] | .Item[] | select( .ItemName == \"Item_2\" ) | .Valid"
    ],
    "data": [
      {
        "input": [
          {
            "GroupId": "1569",
            "Title": "My_title",
            "Logo": "logo.jpg",
            "Tags": [
              "tag1",
              "tag2",
              "tag3"
            ],
            "Owner": [
              {
                "Name": "John Doe",
                "Id": "53335"
              }
            ],
            "ItemId": "209766",
            "Item": [
              {
                "Id": 47744,
                "ItemName": "Item_1",
                "Valid": false
              },
              {
                "Id": 47872,
                "ItemName": "Item_2",
                "Valid": true
              },
              {
                "Id": 47872,
                "ItemName": "Item_3",
                "Valid": false
              }
            ]
          }
        ],
        "output": true
      }
    ],
    "identifier": 43025130
  },
  {
    "context": [
      "with adding `moduleF` to `NamespaceY`. I need to write the file back again to the original source file.",
      "I came close (but no cigar) with:",
      "jq  '. | .git_namespaces[] | select(.name==\"namespaceY\").modules |= (.+ [\"moduleF\"])' config.json",
      "jq '. | select(.git_namespaces[].name==\"namespaceY\").modules |= (.+ [\"moduleF\"])' config.json",
      "The following filter should perform the update you want:",
      "(.git_namespaces[] | select(.name==\"NamespaceY\").modules) += [\"moduleF\"]",
      "Note that the initial '.|' in your attempt is not needed; that \"NamespaceY\" is capitalized in config.json; that the parens as shown are the keys to success; and that += can be used here."
    ],
    "utterance": "Add the value \"moduleF\" to the modules array of the object with name \"NamespaceY\" inside git_namespaces.",
    "expressions": [
      "(.git_namespaces[] | select(.name==\"NamespaceY\").modules) += [\"moduleF\"]"
    ],
    "data": [
      {
        "input": {
          "git_defaults": {
            "branch": "master",
            "email": "jenkins@host",
            "user": "Jenkins"
          },
          "git_namespaces": [
            {
              "name": "NamespaceX",
              "modules": [
                "moduleA",
                "moduleB",
                "moduleC",
                "moduleD"
              ]
            },
            {
              "name": "NamespaceY",
              "modules": [
                "moduleE"
              ]
            }
          ]
        },
        "output": {
          "git_defaults": {
            "branch": "master",
            "email": "jenkins@host",
            "user": "Jenkins"
          },
          "git_namespaces": [
            {
              "name": "NamespaceX",
              "modules": [
                "moduleA",
                "moduleB",
                "moduleC",
                "moduleD"
              ]
            },
            {
              "name": "NamespaceY",
              "modules": [
                "moduleE",
                "moduleF"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 43180340
  },
  {
    "context": [
      "Every object has a name property that I would like to use to sort on",
      "I have found that this works \".model.tables|=sort_by(.name)\" to just sort one collection (thanks to https://stackoverflow.com/questions/30331504/how-to-sort-a-json-file-by-keys-and-values-of-those-keys-in-jq) but I cannot work out how to combine this with the walk so I don\u0019t need to explicitly recreate the same json structure",
      "You can sort all the arrays by \"name\", while keeping everything else intact, like this:",
      "walk(if type == \"array\" then sort_by(.name) else . end)"
    ],
    "utterance": "Sort all arrays in the structure by their objects' name property at every nesting level.",
    "expressions": [
      "walk(if type == \"array\" then sort_by(.name) else . end)"
    ],
    "identifier": 43211290
  },
  {
    "context": [
      "How can I run a Bash command for every JSON object in a JSON array using `jq`? So far I have this:",
      "jq -r '.[]|[.user, .date, .email] | @tsv' |\n  while IFS=$'\\t' read -r user date email; do\n    mycommand -u \"$user\" -d \"$date\" -e \"$email\"\n  done",
      "You could have `jq` output the commands to execute, something like\n\n    .[] | \"mycommand \\(.user|@sh) \\(.date|@sh) \\(.email|@sh)\"\n\nThen execute it. Something like\n\n    bash <(jq -r '.[] | \"mycommand \\(.user|@sh) \\(.date|@sh) \\(.email|@sh)\"' foo)"
    ],
    "utterance": "Run a shell command for each object in an array, using the object's user, date, and email fields as command arguments.",
    "expressions": [
      ".[] | [ .user, .date, .email ] | @tsv",
      ".[] | \"mycommand \\(.user|@sh) \\(.date|@sh) \\(.email|@sh)\""
    ],
    "data": [
      {
        "input": [
          {
            "user": "danielrvt",
            "date": "11/10/1988",
            "email": "myemail@domain.com"
          },
          {
            "user": "alice",
            "date": "01/02/1980",
            "email": "alice@domain.com"
          }
        ]
      }
    ],
    "identifier": 43192556
  },
  {
    "context": [
      "Is there a way to reproduce the same array, but with the keys converted to lowercase using `jq`?",
      "In the particular case you mention, you could use this filter:\r\n\r\n    with_entries( .key |= ascii_downcase )",
      "However, you mention arrays.  If you are referring to JSON arrays, you will have to modify the above.",
      "One possibility would be to use `walk/1`, but your jq might not have it.",
      "Here&#39;s how it could be used:\r\n\r\n    walk(if type==\"object\" then with_entries(.key|=ascii_downcase) else . end)"
    ],
    "utterance": "Convert all object keys in all elements of an array to lowercase.",
    "expressions": [
      "map(with_entries(.key |= ascii_downcase))",
      "walk(if type==\"object\" then with_entries(.key|=ascii_downcase) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "campaignId": "11067182",
            "campaignName": "11067182",
            "channelId": "%pxbid_universal_site_id=!;",
            "channelName": "%pxbid_universal_site_id=!;",
            "placementId": "%epid!",
            "placementName": "%epid!",
            "publisherId": "%esid!",
            "publisherName": "%esid!",
            "hitDate": "2017-03-23",
            "lowRiskImpressions": "61485",
            "lowRiskPct": "64.5295",
            "moderateRiskImpressions": "1887",
            "moderateRiskPct": "1.9804",
            "highRiskImpressions": "43",
            "highRiskPct": "0.0451",
            "veryHighRiskImpressions": "860",
            "veryHighRiskPct": "0.9026",
            "totalRated": "95274",
            "unrated": "8",
            "unratedPct": "0.0084",
            "visibleCount": "64283",
            "pctVisible": "67.4660",
            "invisibleCount": "30999",
            "totalImpressions": "95282"
          },
          {
            "campaignId": "11067182",
            "campaignName": "11067182",
            "channelId": "%pxbid_universal_site_id=!;",
            "channelName": "%pxbid_universal_site_id=!;",
            "placementId": "%epid!",
            "placementName": "%epid!",
            "publisherId": "%esid!",
            "publisherName": "%esid!",
            "hitDate": "2017-03-22",
            "lowRiskImpressions": "17929",
            "lowRiskPct": "52.9379",
            "moderateRiskImpressions": "1872",
            "moderateRiskPct": "5.5273",
            "highRiskImpressions": "9",
            "highRiskPct": "0.0266",
            "veryHighRiskImpressions": "139",
            "veryHighRiskPct": "0.4104",
            "totalRated": "33850",
            "unrated": "18",
            "unratedPct": "0.0531",
            "visibleCount": "19967",
            "pctVisible": "58.9554",
            "invisibleCount": "13901",
            "totalImpressions": "33868"
          }
        ],
        "output": [
          {
            "campaignid": "11067182",
            "campaignname": "11067182",
            "channelid": "%pxbid_universal_site_id=!;",
            "channelname": "%pxbid_universal_site_id=!;",
            "placementid": "%epid!",
            "placementname": "%epid!",
            "publisherid": "%esid!",
            "publishername": "%esid!",
            "hitdate": "2017-03-23",
            "lowriskimpressions": "61485",
            "lowriskpct": "64.5295",
            "moderateriskimpressions": "1887",
            "moderateriskpct": "1.9804",
            "highriskimpressions": "43",
            "highriskpct": "0.0451",
            "veryhighriskimpressions": "860",
            "veryhighriskpct": "0.9026",
            "totalrated": "95274",
            "unrated": "8",
            "unratedpct": "0.0084",
            "visiblecount": "64283",
            "pctvisible": "67.4660",
            "invisiblecount": "30999",
            "totalimpressions": "95282"
          },
          {
            "campaignid": "11067182",
            "campaignname": "11067182",
            "channelid": "%pxbid_universal_site_id=!;",
            "channelname": "%pxbid_universal_site_id=!;",
            "placementid": "%epid!",
            "placementname": "%epid!",
            "publisherid": "%esid!",
            "publishername": "%esid!",
            "hitdate": "2017-03-22",
            "lowriskimpressions": "17929",
            "lowriskpct": "52.9379",
            "moderateriskimpressions": "1872",
            "moderateriskpct": "5.5273",
            "highriskimpressions": "9",
            "highriskpct": "0.0266",
            "veryhighriskimpressions": "139",
            "veryhighriskpct": "0.4104",
            "totalrated": "33850",
            "unrated": "18",
            "unratedpct": "0.0531",
            "visiblecount": "19967",
            "pctvisible": "58.9554",
            "invisiblecount": "13901",
            "totalimpressions": "33868"
          }
        ]
      }
    ],
    "identifier": 43038453
  },
  {
    "context": [
      "I want to change the `\"image\": \"docker.org/alpha/alpha-app-newgen:12.2.3\"` value in Json to `\"image\": \"docker.org/alpha/alpha-app-newgen:12.5.0\"` or any other version dynamically.",
      "I need to get the same structure back with new value for the image.",
      "walk(if type == \"object\" and .image == $old then .image=$new else . end)",
      ".taskDefinition.containerDefinitions[].image |= (if . == $old then $new else . end)"
    ],
    "utterance": "Replace the value of the image field where it equals docker.org/alpha/alpha-app-newgen:12.2.3 with a new value, preserving the structure.",
    "expressions": [
      "walk(if type == \"object\" and .image == $old then .image=$new else . end)",
      ".taskDefinition.containerDefinitions[].image |= (if . == $old then $new else . end)"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "family": "ing-stack",
            "volumes": [
              {
                "host": {
                  "sourcePath": "/tmp/nginx/elb.conf"
                },
                "name": "volume-0"
              }
            ],
            "containerDefinitions": [
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "API_SECRET",
                    "value": "ING-SECRET"
                  },
                  {
                    "name": "API_KEY",
                    "value": "AVERA-CADA-VERA-KEY"
                  }
                ],
                "readonlyRootFilesystem": false,
                "name": "ing-stg",
                "links": [],
                "mountPoints": [],
                "image": "docker.org/alpha/alpha-app-newgen:12.2.3",
                "privileged": false,
                "essential": true,
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 19000,
                    "hostPort": 19000
                  }
                ],
                "dockerLabels": {}
              },
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "NG_PROXY",
                    "value": "ing"
                  }
                ],
                "readonlyRootFilesystem": false,
                "name": "web",
                "links": [
                  "identity-ng"
                ],
                "mountPoints": [
                  {
                    "sourceVolume": "volume-0",
                    "readOnly": false,
                    "containerPath": "/etc/nginx/conf.d/default.conf"
                  }
                ],
                "image": "docker.org/alpha/alpha-ui:6.4.7",
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 443,
                    "hostPort": 443
                  },
                  {
                    "protocol": "tcp",
                    "containerPort": 80,
                    "hostPort": 80
                  }
                ],
                "memory": 512,
                "command": [
                  "sh",
                  "prep-run-nginx.sh"
                ],
                "dockerLabels": {}
              }
            ],
            "revision": 136
          }
        },
        "output": {
          "taskDefinition": {
            "family": "ing-stack",
            "volumes": [
              {
                "host": {
                  "sourcePath": "/tmp/nginx/elb.conf"
                },
                "name": "volume-0"
              }
            ],
            "containerDefinitions": [
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "API_SECRET",
                    "value": "ING-SECRET"
                  },
                  {
                    "name": "API_KEY",
                    "value": "AVERA-CADA-VERA-KEY"
                  }
                ],
                "readonlyRootFilesystem": false,
                "name": "ing-stg",
                "links": [],
                "mountPoints": [],
                "image": "docker.org/alpha/alpha-app-newgen:12.5.0",
                "privileged": false,
                "essential": true,
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 19000,
                    "hostPort": 19000
                  }
                ],
                "dockerLabels": {}
              },
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "NG_PROXY",
                    "value": "ing"
                  }
                ],
                "readonlyRootFilesystem": false,
                "name": "web",
                "links": [
                  "identity-ng"
                ],
                "mountPoints": [
                  {
                    "sourceVolume": "volume-0",
                    "readOnly": false,
                    "containerPath": "/etc/nginx/conf.d/default.conf"
                  }
                ],
                "image": "docker.org/alpha/alpha-ui:6.4.7",
                "portMappings": [
                  {
                    "protocol": "tcp",
                    "containerPort": 443,
                    "hostPort": 443
                  },
                  {
                    "protocol": "tcp",
                    "containerPort": 80,
                    "hostPort": 80
                  }
                ],
                "memory": 512,
                "command": [
                  "sh",
                  "prep-run-nginx.sh"
                ],
                "dockerLabels": {}
              }
            ],
            "revision": 136
          }
        }
      }
    ],
    "identifier": 43053569
  },
  {
    "context": [
      "How the heck do I get the `HostPort` value? I tried the following but that failed.",
      "`jq` supports double quotes for keys with special characters:",
      "jq '.\"22/tcp\".HostPort'",
      "you can add brackets to help with readability, if you want:",
      "jq '.[\"22/tcp\"].HostPort'",
      "The above answer is close but needs to add a bracket to work correctly.",
      "jq '.\"22/tcp\"[].HostPort'"
    ],
    "utterance": "Select the HostPort value for the 22/tcp port key, which contains a slash character.",
    "expressions": [
      ".[\"22/tcp\"][0].HostPort",
      ".[\"22/tcp\"][] | .HostPort",
      ".\"22/tcp\"[0].HostPort",
      ".\"22/tcp\"[] | .HostPort"
    ],
    "data": [
      {
        "input": {
          "22/tcp": [
            {
              "HostIp": "0.0.0.0",
              "HostPort": "32776"
            }
          ]
        },
        "output": "32776"
      }
    ],
    "identifier": 43214376
  },
  {
    "context": [
      "My goal is to convert the start and end times to epoch and workout the duration in seconds. Then output the same object with the new values.",
      "I can get the individual values of each variables but not sure how to then concatenate them all in a single output object.",
      "You could chain together the updates like so:",
      ".Start |= (strptime(\"%Y-%m-%d %H:%M:%S\") | mktime)\n| .End |= (strptime(\"%Y-%m-%d %H:%M:%S\") | mktime)\n| .Period = (.End - .Start)"
    ],
    "utterance": "Convert the Start and End fields from date strings to epoch seconds and set Period to the difference between End and Start, outputting a single object with these updated fields.",
    "expressions": [
      ".Start |= (strptime(\"%Y-%m-%d %H:%M:%S\") | mktime) | .End |= (strptime(\"%Y-%m-%d %H:%M:%S\") | mktime) | .Period = (.End - .Start)"
    ],
    "data": [
      {
        "input": {
          "Status": "Down",
          "StatusID": "75328241",
          "Start": "2017-03-17 15:06:40",
          "End": "2017-03-17 15:08:37",
          "Period": "1 Minutes "
        },
        "output": {
          "Status": "Down",
          "StatusID": "75328241",
          "Start": 1489763200,
          "End": 1489763317,
          "Period": 117
        }
      }
    ],
    "identifier": 43213672
  },
  {
    "context": [
      "What I want is, given a mobile number and no. of calls made for that mobile on a particular day, update the json (update both the individual counter and the total)",
      "Eg. Let's say for number `44444` calls made are 5, then the final json should be",
      "{ ... { \"number\": \"44444\", \"calls\": 7 }, ... \"total\": 9 ... }",
      "To update the relevant \"calls\" along the lines you were exploring:",
      "map( (.mobiles[] | select(.number == $number) | .calls) += $incr)",
      "To update the relevant \"total\", you could use `any/2`:",
      "map( if any(.mobiles[]; .number == $number) then .total += $incr else . end)"
    ],
    "utterance": "Increase the 'calls' field by 5 for the mobile with number '44444' and also increase the 'total' field by 5 for the corresponding person.",
    "expressions": [
      "map( (.mobiles[] | select(.number == $number) | .calls) += $incr ) | map( if any(.mobiles[]; .number == $number) then .total += $incr else . end )",
      "map( if any(.mobiles[]; .number == $number)\n     then .mobiles |= map(if .number == $number then .calls += $incr else . end) | .total += $incr\n     else .\n     end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Person1",
            "mobiles": [
              {
                "number": "11111",
                "calls": 2
              },
              {
                "number": "22222",
                "calls": 3
              }
            ],
            "total": 5
          },
          {
            "name": "Person2",
            "mobiles": [
              {
                "number": "33333",
                "calls": 1
              },
              {
                "number": "44444",
                "calls": 2
              },
              {
                "number": "55555",
                "calls": 1
              }
            ],
            "total": 4
          }
        ],
        "output": [
          {
            "name": "Person1",
            "mobiles": [
              {
                "number": "11111",
                "calls": 2
              },
              {
                "number": "22222",
                "calls": 3
              }
            ],
            "total": 5
          },
          {
            "name": "Person2",
            "mobiles": [
              {
                "number": "33333",
                "calls": 1
              },
              {
                "number": "44444",
                "calls": 7
              },
              {
                "number": "55555",
                "calls": 1
              }
            ],
            "total": 9
          }
        ]
      }
    ],
    "identifier": 43158831
  },
  {
    "context": [
      "I want to add the key/field:\n\n    \"codefile\" : \"a string to be defined\"\n\nwithin the question[] items to get something like:\n\n      {\n        \"ID\": \"Q1\",\n        \"categoryname\": \"General\",\n        \"idC\": \"C1\",\n        \"idCQ\": \"C1Q1\",\n        \"idQ\": \"Q1\",\n        \"title\": \"Find the most frequent integer in an array\",\n        \"codefile\" : \"not present\"\n      },",
      "What&#39;s wrong with:\n\n    .TechQuestions.category[0,1].question[] += {\"codefile\" : \"a string to be defined\"}",
      "Using `walk/1`, you could consider:\n\n    walk( if type == \"object\" and has(\"question\")\n          then .question[] += {\"codefile\" : \"a string to be defined\"}\n          else .\n          end)"
    ],
    "utterance": "Add a key named codefile with the value \"a string to be defined\" to each object within every question array under TechQuestions.category.",
    "expressions": [
      ".TechQuestions.category[].question[] += {\"codefile\": \"a string to be defined\"}",
      "walk(if type == \"object\" and has(\"question\") then .question[] += {\"codefile\": \"a string to be defined\"} else . end)"
    ],
    "data": [
      {
        "input": {
          "TechQuestions": {
            "category": [
              {
                "catname": "General",
                "idC": "C1",
                "question": [
                  {
                    "ID": "Q1",
                    "categoryname": "General",
                    "idC": "C1",
                    "idCQ": "C1Q1",
                    "idQ": "Q1",
                    "title": "Find the most frequent integer in an array"
                  },
                  {
                    "ID": "Q2",
                    "categoryname": "General",
                    "idC": "C1",
                    "idCQ": "C1Q2",
                    "idQ": "Q2",
                    "title": "Find pairs in an integer array whose sum is equal to 10 (bonus; do it in linear time)"
                  }
                ]
              },
              {
                "catname": "Strings",
                "idC": "C2",
                "question": [
                  {
                    "ID": "Q21",
                    "categoryname": "Strings",
                    "idC": "C2",
                    "idCQ": "C2Q1",
                    "idQ": "Q1",
                    "title": "Find the first non-repeated character in a String"
                  },
                  {
                    "ID": "Q22",
                    "categoryname": "Strings",
                    "idC": "C2",
                    "idCQ": "C2Q2",
                    "idQ": "Q2",
                    "title": "Reverse a String iteratively and recursively"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "TechQuestions": {
            "category": [
              {
                "catname": "General",
                "idC": "C1",
                "question": [
                  {
                    "ID": "Q1",
                    "categoryname": "General",
                    "idC": "C1",
                    "idCQ": "C1Q1",
                    "idQ": "Q1",
                    "title": "Find the most frequent integer in an array",
                    "codefile": "a string to be defined"
                  },
                  {
                    "ID": "Q2",
                    "categoryname": "General",
                    "idC": "C1",
                    "idCQ": "C1Q2",
                    "idQ": "Q2",
                    "title": "Find pairs in an integer array whose sum is equal to 10 (bonus; do it in linear time)",
                    "codefile": "a string to be defined"
                  }
                ]
              },
              {
                "catname": "Strings",
                "idC": "C2",
                "question": [
                  {
                    "ID": "Q21",
                    "categoryname": "Strings",
                    "idC": "C2",
                    "idCQ": "C2Q1",
                    "idQ": "Q1",
                    "title": "Find the first non-repeated character in a String",
                    "codefile": "a string to be defined"
                  },
                  {
                    "ID": "Q22",
                    "categoryname": "Strings",
                    "idC": "C2",
                    "idCQ": "C2Q2",
                    "idQ": "Q2",
                    "title": "Reverse a String iteratively and recursively",
                    "codefile": "a string to be defined"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 43148797
  },
  {
    "context": [
      "I'm trying to match values from a bash array with values from json array using jq.",
      "| jq --arg gitlab_tag \"$GITLAB_TAG\" '[ .[] | select(.tag_list[] | contains($gitlab_tag)) ]'",
      "It appears that you should be using `index/1` to check .tag_list (not .tag_list[]):",
      "[ .[] | select(.tag_list | index($gitlab_tag))"
    ],
    "utterance": "Filter objects that have a specific value present in their tag_list field, where the value is provided as a variable.",
    "expressions": [
      "[ .[] | select(.tag_list | index($gitlab_tag)) ]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 31,
            "description": "",
            "default_branch": null,
            "tag_list": [
              "dev",
              "app"
            ],
            "archived": false,
            "visibility": "private"
          },
          {
            "id": 28,
            "description": "",
            "default_branch": "master",
            "tag_list": [
              "dev",
              "app"
            ],
            "archived": false,
            "visibility": "private"
          }
        ],
        "output": [
          {
            "id": 31,
            "description": "",
            "default_branch": null,
            "tag_list": [
              "dev",
              "app"
            ],
            "archived": false,
            "visibility": "private"
          },
          {
            "id": 28,
            "description": "",
            "default_branch": "master",
            "tag_list": [
              "dev",
              "app"
            ],
            "archived": false,
            "visibility": "private"
          }
        ]
      }
    ],
    "identifier": 43218242
  },
  {
    "context": [
      "I want to use [tag:sed] to conditionally change the **team** name to **fruit** if the **food** on the line below contains the word  \r\n`raspberry`  \r\n`strawberry`  \r\n`apple`    \r\nbut to leave it alone if the search isn&#39;t matched.",
      "jq 'map(select(.food == \"strawberry\" or .food == \"raspberry\" or .food == \"apple\").team |=\"fruit\")' test.json",
      "The output:\r\n\r\n    [\r\n      {\r\n        \"team\": \"fruit\",\r\n        \"food\": \"raspberry\"\r\n      },\r\n      {\r\n        \"team\": \"veg\",\r\n        \"food\": \"carrot\"\r\n      },\r\n      {\r\n        \"team\": \"fruit\",\r\n        \"food\": \"strawberry\"\r\n      }\r\n    ]"
    ],
    "utterance": "Change the value of team to fruit only for objects where the food field is raspberry, strawberry, or apple; leave other team values unchanged.",
    "expressions": [
      "map(select(.food == \"strawberry\" or .food == \"raspberry\" or .food == \"apple\").team |= \"fruit\")"
    ],
    "data": [
      {
        "input": [
          {
            "team": "veg",
            "food": "raspberry"
          },
          {
            "team": "veg",
            "food": "carrot"
          },
          {
            "team": "veg",
            "food": "strawberry"
          }
        ],
        "output": [
          {
            "team": "fruit",
            "food": "raspberry"
          },
          {
            "team": "veg",
            "food": "carrot"
          },
          {
            "team": "fruit",
            "food": "strawberry"
          }
        ]
      }
    ],
    "identifier": 43231154
  },
  {
    "context": [
      "I would like using the JQ command line to transform a FormData json object into a string like `id=johndoe&amp;password=secret&amp;foo=bar`",
      "Is there a way to create achieve this using only one (or fewer) JQ filter ?",
      "You can use Format Strings and Escaping together with String Interpolation (both section titles in the jq manual) in a map, followed by reduce:\n\n    jq -r '\n      .form_data | \n      to_entries | \n      map(@uri \"\\(.key)=\\(.value)&\") | \n      reduce .[1:][] as $i (.[0]; .+\"&\"+$i)\n    '\n"
    ],
    "utterance": "Convert the form_data object into a URL-encoded parameter string with key-value pairs joined by '&', such as id=johndoe&password=secret&foo=bar.",
    "expressions": [
      ".form_data | to_entries | map(@uri \"\\(.key)=\\(.value)&\") | reduce .[1:][] as $i (.[0]; .+\"&\"+$i)"
    ],
    "data": [
      {
        "input": {
          "name": "example",
          "auth_url": "http://example.com/login",
          "form_data": {
            "id": "johndoe",
            "password": "secret",
            "foo": "bar"
          }
        },
        "output": "id=johndoe&password=secret&foo=bar"
      }
    ],
    "identifier": 43234692
  },
  {
    "context": [
      "I need to combine the results though, so duplicate keys have only one array of values.",
      "I need to do it without having to put in the key (\"1.NBT.B\") directly, since there are hundreds of these keys.",
      "The following jq function combines an array of objects in the manner envisioned by the first part of the question.",
      "def merge:\n  reduce .[] as $o ({}; reduce ($o|keys)[] as $key (.; .[$key] += $o[$key] ));",
      "merge | with_entries( .value |= map(.id) )"
    ],
    "utterance": "Combine all objects in an array into a single object where, for each key present, the arrays of values are concatenated, and then map the arrays to only the 'id' fields.",
    "expressions": [
      "def merge: reduce .[] as $o ({}; reduce ($o|keys)[] as $key (.; .[$key] += $o[$key] )); merge | with_entries( .value |= map(.id) )"
    ],
    "data": [
      {
        "input": [
          {
            "1.NBT.B": [
              {
                "id": 545
              },
              {
                "id": 546
              }
            ]
          },
          {
            "1.NBT.B": [
              {
                "id": 1281
              },
              {
                "id": 1077
              }
            ]
          }
        ],
        "output": {
          "1.NBT.B": [
            545,
            546,
            1281,
            1077
          ]
        }
      }
    ],
    "identifier": 43337056
  },
  {
    "context": [
      "`cat input/file1.json | jq '.responses[0] | {labelAnnotations: .labelAnnotations}' > output/file1.json`",
      "Now, there are thousands of input JSON files, and I like to leverage GNU Parallel to parallelize all process.",
      "parallel doit {} output/{/} ::: input/*.json",
      "jq '.responses[0] | {labelAnnotations: .labelAnnotations}'"
    ],
    "utterance": "Extract the labelAnnotations field from the first object in the responses array for each file.",
    "expressions": [
      ".responses[0] | {labelAnnotations: .labelAnnotations}"
    ],
    "identifier": 43389055
  },
  {
    "context": [
      "I want to get:\r\n\r\n    [\r\n      \"age\",\r\n      \"name\",\r\n      \"visits.2017-01-25\",\r\n      \"visits.2016-07-26\",\r\n      \"visits.2016-01-24\"\r\n    ]",
      "I am able to extract the keys using: `jq '. | keys' file.json`, but this skips nested fields. How to include those?",
      "With your input, the invocation:\r\n\r\n    jq 'leaf_paths | join(\".\")'\r\n\r\nproduces:\r\n\r\n    \"name\"\r\n    \"age\"\r\n    \"visits.2017-01-25\"\r\n    \"visits.2016-07-26\"\r\n    \"visits.2016-01-24\"\r\n\r\nIf you want to include \"visits\", use `paths`.  If you want the result as a JSON array, enclose the filter with square brackets: [ ... ]",
      "the invocation:\r\n    jq 'leaf_paths | join(\".\")'\r\nproduces:\r\n    \"name\"\r\n    \"age\"\r\n    \"visits.2017-01-25\"\r\n    \"visits.2016-07-26\"\r\n    \"visits.2016-01-24\"",
      "If you want the result as a JSON array, enclose the filter with square brackets: [ ... ]"
    ],
    "utterance": "List all dotted key paths to scalar values, including those inside nested objects, as an array.",
    "expressions": [
      "[leaf_paths | join(\".\")]",
      "paths(scalars) | map(tostring) | join(\".\") | [.]"
    ],
    "data": [
      {
        "input": {
          "name": "tom",
          "age": 12,
          "visits": {
            "2017-01-25": 3,
            "2016-07-26": 4,
            "2016-01-24": 1
          }
        },
        "output": [
          "name",
          "age",
          "visits.2017-01-25",
          "visits.2016-07-26",
          "visits.2016-01-24"
        ]
      }
    ],
    "identifier": 43379692
  },
  {
    "context": [
      "I want them to be in order of their seed. I\u2019ve tried using sort and sort_by in various ways to no avail. I\u2019m out of ideas.",
      "jq -r '\ndef NameAndSeed(f): f | {nameRaw, \"teamSeed\" : (.teamSeed | tonumber)};\n[ \n  .scoreboard[].games[]\n  | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\")\n  | NameAndSeed(.home), NameAndSeed(.away)\n]\n| sort_by(.teamSeed) \n| .[].nameRaw'",
      "[ .scoreboard[].games[]\n  | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\")\n  | (.home, .away) ]\n| sort_by(.teamSeed | tonumber) \n| .[]\n| [.teamSeed, .nameRaw ]",
      "If you just want the \"nameRaw\" values, then replace the last line of the filter by: | .nameRaw",
      "def games:\n  [.scoreboard[].games[]\n   | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\")\n   | (.home, .away) ] ;\n\nmap(games)\n| add\n| sort_by(.teamSeed | tonumber) \n| .[]\n| [.teamSeed, .nameRaw ]"
    ],
    "utterance": "List all teams from the 'First Round' in the 'EAST' bracket region, ordered by their numerical seed.",
    "expressions": [
      "[ .scoreboard[].games[] | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\") | (.home, .away) ] | sort_by(.teamSeed | tonumber) | .[].nameRaw",
      "[ .scoreboard[].games[] | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\") | (.home, .away) ] | sort_by(.teamSeed | tonumber) | .[] | [.teamSeed, .nameRaw ]",
      "def games: [ .scoreboard[].games[] | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\") | (.home, .away) ]; map(games) | add | sort_by(.teamSeed | tonumber) | .[].nameRaw",
      "def games: [ .scoreboard[].games[] | select(.bracketRound==\"First Round\" and .bracketRegion==\"EAST\") | (.home, .away) ]; map(games) | add | sort_by(.teamSeed | tonumber) | .[] | [.teamSeed, .nameRaw ]"
    ],
    "identifier": 43300736
  },
  {
    "context": [
      "I have an array and I need to check if elements exists in that array or to get that element from the array using jq, **fruit.json**:",
      "cat fruit.json | jq '.fruit .apple' \r\ndoes not work",
      "cat fruit.json | jq '.fruit | contains([\"orange\"])'",
      ".fruit | index( \"orange\" )",
      ".fruit as $f | \"orange\" | IN($f[])",
      "any(.fruit[]; . == \"orange\")",
      "jq -e '.fruit|any(. == \"apple\")' fruit.json > /dev/null",
      "jq -e '.fruit[]|select(. == \"apple\")' fruit.json",
      "jq -r '.fruit | index( \"orange\" )' fruit.json | tail -n 1",
      "If it exist, it returns `0`.\r\nIf don't, it returns `null`."
    ],
    "utterance": "Check whether \"orange\" exists in the array under the key \"fruit\".",
    "expressions": [
      ".fruit | contains([\"orange\"])",
      ".fruit | index(\"orange\")",
      "any(.fruit[]; . == \"orange\")",
      ".fruit as $f | \"orange\" | IN($f[])"
    ],
    "data": [
      {
        "input": {
          "fruit": [
            "apple",
            "orange",
            "pomegranate",
            "apricot",
            "mango"
          ]
        },
        "output": true
      }
    ],
    "identifier": 43259563
  },
  {
    "context": [
      "I need find the entry where `Tags.Key == \"hc-class\"` and `Tags.Value = \"staging-standalone\"`, how do I do it in a succinct way with `jq`?",
      ".[] | select(any(.Tags[]; .Key == \"hc-class\" and .Value == \"staging-standalone\"))"
    ],
    "utterance": "Find resources where a tag has Key equal to \"hc-class\" and Value equal to \"staging-standalone\".",
    "expressions": [
      ".[] | select(any(.Tags[]; .Key == \"hc-class\" and .Value == \"staging-standalone\"))"
    ],
    "data": [
      {
        "input": [
          {
            "PublicIpAddress": "11.22.33.44",
            "PrivateIpAddress": "55.66.77.88",
            "Tags": [
              {
                "Value": "live199.blah.com",
                "Key": "Name"
              },
              {
                "Value": "live-standalone",
                "Key": "hc-class"
              }
            ]
          },
          {
            "PublicIpAddress": "111.222.333.444",
            "PrivateIpAddress": "555.666.777.888",
            "Tags": [
              {
                "Value": "staging99.blah.com",
                "Key": "Name"
              },
              {
                "Value": "staging-standalone",
                "Key": "hc-class"
              }
            ]
          }
        ],
        "output": {
          "PublicIpAddress": "111.222.333.444",
          "PrivateIpAddress": "555.666.777.888",
          "Tags": [
            {
              "Value": "staging99.blah.com",
              "Key": "Name"
            },
            {
              "Value": "staging-standalone",
              "Key": "hc-class"
            }
          ]
        }
      }
    ],
    "identifier": 43397216
  },
  {
    "context": [
      "What I really want is to first replace any leading or trailing space in \"text\", then catenate all \"text\" properties. A difference being that embedded (non-leading, non-trailing) spaces must not be removed.",
      "def trim: sub(\"^ *\";\"\") | sub(\" *$\";\"\");",
      "Or you could simply use: gsub(\"^\\\\s|\\\\s*$\";\"\")"
    ],
    "utterance": "Concatenate all 'text' properties after removing leading and trailing spaces from each while preserving embedded spaces.",
    "expressions": [
      ".segments[].words | map(.text | gsub(\"^\\s|\\s*$\";\"\")) | join(\" \")",
      ".segments[].words | map(.text | sub(\"^ *\";\"\") | sub(\" *$\";\"\")) | join(\" \")"
    ],
    "identifier": 43475525
  },
  {
    "context": [
      "I want to make a query using jq where if my node key is \"cp-phix-app-uat14.hcinternal.net:80\" then put state as \"active' so my output should be like :-",
      "map( if .node ==  \"cp-phix-app-uat14.hcinternal.net:80\"\n         then .state = \"active\"\n         else .\n         end )"
    ],
    "utterance": "Set the state field to \"active\" for all objects where node equals \"cp-phix-app-uat14.hcinternal.net:80\".",
    "expressions": [
      "map( if .node == \"cp-phix-app-uat14.hcinternal.net:80\" then .state = \"active\" else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "node": "cp-phix-app-uat14.hcinternal.net:80",
            "priority": 1,
            "state": "draining",
            "weight": 1
          },
          {
            "node": "cp-phix-app-uat13.hcinternal.net:80",
            "priority": 1,
            "state": "active",
            "weight": 1
          }
        ],
        "output": [
          {
            "node": "cp-phix-app-uat14.hcinternal.net:80",
            "priority": 1,
            "state": "active",
            "weight": 1
          },
          {
            "node": "cp-phix-app-uat13.hcinternal.net:80",
            "priority": 1,
            "state": "active",
            "weight": 1
          }
        ]
      }
    ],
    "identifier": 43466783
  },
  {
    "context": [
      "I need to pull a couple of fields and assign the values to variables that I can continue to use in my bash script.",
      "I tried `jq '.data | {episodeName:$name}'` and `jq '.data | .episodeName as $name'` just to try and get one working.",
      "IFS='|' read var1 var2 var3 var4 < <(curl '......' | jq -r '.data |         map([.absoluteNumber, .airedEpisodeNumber, .episodeName, .overview] |         join(\"|\")) | join(\"\\n\")')",
      ".data[] | ( .episodeName, .id )"
    ],
    "utterance": "Extract multiple fields\u2014such as absoluteNumber, airedEpisodeNumber, episodeName, and overview\u2014from each object in the array under the data key, outputting them in a way suitable for assignment to bash variables in a single command.",
    "expressions": [
      ".data | map([.absoluteNumber, .airedEpisodeNumber, .episodeName, .overview] | join(\"|\")) | join(\"\\n\")",
      ".data[] | (.episodeName, .id)"
    ],
    "data": [
      {
        "input": [
          {
            "absoluteNumber": 51,
            "airedEpisodeNumber": 6,
            "airedSeason": 4,
            "airedSeasonID": 680431,
            "dvdEpisodeNumber": 6,
            "dvdSeason": 4,
            "episodeName": "We Will Rise",
            "firstAired": "2017-03-15",
            "id": 5939660,
            "language": {
              "episodeName": "en",
              "overview": "en"
            },
            "lastUpdated": 1490769062,
            "overview": "Clarke and Roan must work together in hostile territory in order to deliver an invaluable asset to Abby and her team."
          }
        ],
        "output": [
          "51|6|We Will Rise|Clarke and Roan must work together in hostile territory in order to deliver an invaluable asset to Abby and her team."
        ]
      }
    ],
    "identifier": 43291389
  },
  {
    "context": [
      "I am trying to output this\n\n    [\n      {\n        \"id\": \"001\",\n        \"Item1\": 1,\n        \"Name\": \"name2\"\n      },\n      {\n        \"id\": \"002\",\n        \"Item1\": 1,\n        \"Name\": null\n      },\n      {\n        \"id\": \"003\",\n        \"Item1\": null,\n        \"Name\": \"name2\"\n      }\n    ]",
      "If you `map` the `select` onto the _records_ array instead, the surrounding object is not removed. For example:",
      "    [\n      .data[] | \n      {\n        id    : .id,\n        Item1 : .metadata.item1,\n        Name  : .records | map(select(.type == \"type2\"))[0].name\n      }\n    ]"
    ],
    "utterance": "For each object in the top-level \"data\" array, extract an object with keys: id (from .id), Item1 (from .metadata.item1, or null if missing), and Name (the name from the first element in .records with type equal to \"type2\", or null if not present).",
    "expressions": [
      "[.data[] | {id: .id, Item1: .metadata.item1, Name: (.records | map(select(.type == \"type2\"))[0].name)}]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "001",
              "metadata": {
                "item1": 1
              },
              "records": [
                {
                  "name": "name1",
                  "type": "type1"
                },
                {
                  "name": "name2",
                  "type": "type2"
                }
              ]
            },
            {
              "id": "002",
              "metadata": {
                "item1": 1
              },
              "records": [
                {
                  "name": "name1",
                  "type": "type1"
                }
              ]
            },
            {
              "id": "003",
              "metadata": {},
              "records": [
                {
                  "name": "name1",
                  "type": "type1"
                },
                {
                  "name": "name2",
                  "type": "type2"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "001",
            "Item1": 1,
            "Name": "name2"
          },
          {
            "id": "002",
            "Item1": 1,
            "Name": null
          },
          {
            "id": "003",
            "Item1": null,
            "Name": "name2"
          }
        ]
      }
    ],
    "identifier": 43424542
  },
  {
    "context": [
      "I have the two following json files.",
      "I want to obtain this :",
      "{'field1':{'item1':0,'array1':[0,0,0,1,1,1],'array2':[0,0,1,1],'array3':[0,1]},'field2':{'dummy':0}}",
      "I am able to do it manually array by array but I would prefer a method to do it automatically for each array of field1. Does someone have a tip for me ?",
      "def extend_arrays(o):\n  reduce keys[] as $k \n    (.; if (.[$k]|type) == \"array\" and (o[$k]|type == \"array\")\n        then .[$k] += o[$k] else . end);\n\n.field1 |= extend_arrays($second|.field1)",
      "jq -c --argfile second file2.json -f program.jq file1.json",
      "produces the required output:",
      "{\"field1\":{\"item1\":0,\"array1\":[0,0,0,1,1,1],\"array2\":[0,0,1,1],\"array3\":[0,1]},\"field2\":{\"dummy\":0}}"
    ],
    "utterance": "Merge all arrays that are direct fields under 'field1' from two files, concatenating their values while keeping non-arrays unchanged.",
    "expressions": [
      "def extend_arrays(o): reduce keys[] as $k (.; if (.[$k]|type) == \"array\" and (o[$k]|type == \"array\") then .[$k] += o[$k] else . end); .field1 |= extend_arrays($second|.field1)"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "field1": {
              "item1": 0,
              "array1": [
                0,
                0,
                0
              ],
              "array2": [
                0,
                0
              ],
              "array3": [
                0
              ]
            },
            "field2": {
              "dummy": 0
            }
          },
          "file2": {
            "field1": {
              "item1": 1,
              "array1": [
                1,
                1,
                1
              ],
              "array2": [
                1,
                1
              ],
              "array3": [
                1
              ]
            },
            "field2": {
              "dummy": 0
            }
          }
        },
        "output": {
          "field1": {
            "item1": 0,
            "array1": [
              0,
              0,
              0,
              1,
              1,
              1
            ],
            "array2": [
              0,
              0,
              1,
              1
            ],
            "array3": [
              0,
              1
            ]
          },
          "field2": {
            "dummy": 0
          }
        }
      }
    ],
    "identifier": 43418382
  },
  {
    "context": [
      "Now I'd like to group and key that by the component and assign a list of ips to each of the components:\r\n\r\n    {\r\n      \"name1\": [\r\n        \"1.1.1.1\",\r\n        \"1.1.1.2\"\r\n      ]\r\n    },{\r\n      \"name2\": [\r\n        \"1.1.1.3\",\r\n        \"1.1.1.4\"\r\n      ]\r\n    }",
      "I first group by `.component` and then just create new lists of ips that are indexed by the component of the first object of each group:\r\n\r\n`jq ' group_by(.component)[] | {(.[0].component): [.[] | .ip]}'",
      "The following `jq` statement results in the desired output as specified in the question:\r\n\r\n````jq\r\ngroup_by(.component) | map({ key: .[0].component, value: [.[] | .ip] }) | from_entries\r\n````",
      "As an simpler alternative to yaccob's answer, you can just use the `add` operator to merge the list of JSON objects into a single object.\r\n\r\n```\r\njq '[group_by(.component)[] | {(.[0].component): [.[] | .ip]}] | add'\r\n```"
    ],
    "utterance": "Group the objects by their component and for each component, list all associated ips, resulting in an object mapping component names to arrays of ips.",
    "expressions": [
      "group_by(.component) | map({ key: .[0].component, value: [.[] | .ip] }) | from_entries",
      "[group_by(.component)[] | {(.[0].component): [.[] | .ip]}] | add"
    ],
    "data": [
      {
        "input": [
          {
            "ip": "1.1.1.1",
            "component": "name1"
          },
          {
            "ip": "1.1.1.2",
            "component": "name1"
          },
          {
            "ip": "1.1.1.3",
            "component": "name2"
          },
          {
            "ip": "1.1.1.4",
            "component": "name2"
          }
        ],
        "output": {
          "name1": [
            "1.1.1.1",
            "1.1.1.2"
          ],
          "name2": [
            "1.1.1.3",
            "1.1.1.4"
          ]
        }
      }
    ],
    "identifier": 43221453
  },
  {
    "context": [
      "I am working on a script to combine my AWS Security Groups and Instances so I can have a consolidated list that looks something like this, in Excel/CSV format:\r\n\r\n    Security Groups | Security Group Name | Instances | Rules | Source\r\n    SG1             | GroupName           | Instance1 | :80   | 0.0.0.0\\0\r\n                    |                     | Instance2 | :443  | 0.0.0.0\\0",
      "I have the instance ID's, and now I have all of the SG information. My problem now finding a way to output it in the format I describe above...",
      "Convert that silly Json to beautiful csv...\r\n    newrules=$(echo $rules|jq --compact-output --raw-output '{SGID: .[].GroupId, Description: .[].Description,Protocol: .[].IpPermissions[].IpProtocol, Port: .[].IpPermissions[].FromPort, CIDR: .[].IpPermissions[].IpRanges[].CidrIp} | flatten | @csv')"
    ],
    "utterance": "Produce a flattened, CSV-ready list showing each security group, group name, associated instance, protocol, port, and CIDR source for all EC2 instances and their security groups.",
    "expressions": [
      "{SGID: .[].GroupId, Description: .[].Description,Protocol: .[].IpPermissions[].IpProtocol, Port: .[].IpPermissions[].FromPort, CIDR: .[].IpPermissions[].IpRanges[].CidrIp} | flatten | @csv"
    ],
    "identifier": 43499236
  },
  {
    "context": [
      "How do I grab each line and get the codes and key name and output them into JSON format?",
      "If you want the result as a single array, then you could pipe the above into `jq -s .`.",
      "$ jq -c -R 'split(\" \") | {code: .[1], key: .[2]}' input.txt",
      "[splits(\" +\")] | {code: .[1], key: .[2]}"
    ],
    "utterance": "Convert each line containing a code and key name into an array of objects with fields 'code' and 'key', extracting these from the second and third whitespace-separated tokens of each line.",
    "expressions": [
      "jq -c -R 'split(\" \") | {code: .[1], key: .[2]}' input.txt | jq -s .",
      "jq -R '[split(\" \") | {code: .[1], key: .[2]}]' input.txt",
      "jq -R '[splits(\" +\") | {code: .[1], key: .[2]}]' input.txt"
    ],
    "data": [
      {
        "input": "irsend: 00000000000010ef KEY_POWER\nirsend: 0000000000008877 KEY_1\nirsend: 00000000000048b7 KEY_2",
        "output": [
          {
            "code": "00000000000010ef",
            "key": "KEY_POWER"
          },
          {
            "code": "0000000000008877",
            "key": "KEY_1"
          },
          {
            "code": "00000000000048b7",
            "key": "KEY_2"
          }
        ]
      }
    ],
    "identifier": 43477830
  },
  {
    "context": [
      "Is it possible and if so how to merge/join/concat values with the same key so that the result is:\n\n    [\n      {\n        \"key\": \"john\",\n        \"value\": \"toronto ontario\"\n      },\n      {\n        \"key\": \"ryan\",\n        \"value\": \"illinois chicago\"\n      },\n    ]",
      "Group the pairs by key, then combine the values.\n\n    group_by(.key) | map({key:.[0].key,value:(map(.value) | join(\" \"))})",
      "def merge_by_key(separator):\n  reduce .[] as $o\n    ({}; $o[\"key\"] as $k\n         | if .[$k] then .[$k] += (separator + $o[\"value\"])\n           else .[$k] = $o[\"value\"] end);\n\nmerge_by_key(\" \") | to_entries"
    ],
    "utterance": "Combine all values sharing the same key into a single string, separated by a space, producing an array of objects with unique keys.",
    "expressions": [
      "group_by(.key) | map({key:.[0].key, value: (map(.value) | join(\" \"))})",
      "def merge_by_key(separator): reduce .[] as $o ({}; $o[\"key\"] as $k | if .[$k] then .[$k] += (separator + $o[\"value\"]) else .[$k] = $o[\"value\"] end); merge_by_key(\" \") | to_entries"
    ],
    "data": [
      {
        "input": [
          {
            "key": "john",
            "value": "ontario"
          },
          {
            "key": "ryan",
            "value": "chicago"
          },
          {
            "key": "ryan",
            "value": "illinois"
          },
          {
            "key": "john",
            "value": "toronto"
          }
        ],
        "output": [
          {
            "key": "john",
            "value": "ontario toronto"
          },
          {
            "key": "ryan",
            "value": "chicago illinois"
          }
        ]
      }
    ],
    "identifier": 43502877
  },
  {
    "context": [
      "I want to rename a few keys (ideally with jq`)`, whatever I do seems to error though.",
      "I\u2019d like to rename the `veg` key to `fruit2` (or example, whatever is easiest) and also the `worker` key to `job`.",
      "with_entries(if .key == \"veg\" then .key = \"fruit2\" else . end)",
      "jq '[.[] | .[\"fruit2\"] = .veg | .[\"job\"] = .worker | del(.veg, .worker)]' file",
      "map(with_entries(.key |=\n  if . == \"fruit\"  then \"fruit2\"\nelif . == \"worker\" then \"job\"\nelse . end))"
    ],
    "utterance": "Rename the veg key to fruit2 and the worker key to job in each object of the array.",
    "expressions": [
      "map(with_entries(if .key == \"veg\" then .key = \"fruit2\" elif .key == \"worker\" then .key = \"job\" else . end))",
      "[.[] | .[\"fruit2\"] = .veg | .[\"job\"] = .worker | del(.veg, .worker)]",
      "map(with_entries(.key |= if . == \"veg\" then \"fruit2\" elif . == \"worker\" then \"job\" else . end))"
    ],
    "data": [
      {
        "input": [
          {
            "fruit": "strawberry",
            "veg": "apple",
            "worker": "gardener"
          }
        ],
        "output": [
          {
            "fruit": "strawberry",
            "fruit2": "apple",
            "job": "gardener"
          }
        ]
      }
    ],
    "identifier": 43522133
  },
  {
    "context": [
      "I wrote the following jq with help from others \r\n\r\n    jq -r '.buckets[].latest.hits.hits[]._source | [.\"is_external\",.\"time_ms\"] | @csv'\r\n\r\nI need to add the perf_QS_Percentiles to the CSV but getting an error.",
      "jq -r '.buckets[].latest.hits.hits[]._source | [.\"is_external\",.\"time_ms\"], .buckets[].perf_QS_percentiles.values | [.\"80.0\",.\"95.0\"]  | @csv'",
      "jq: error (at <stdin>:734665): Cannot index array with string",
      "You can use `(....) + (....)` to create the array before piping to `@csv` :",
      "jq -r '.buckets[] |\n    (.latest.hits.hits[]._source | [.\"is_external\",.\"time_ms\"]) + \n    (.perf_QS_percentiles.values | [.\"80.0\",.\"95.0\"]) | @csv'"
    ],
    "utterance": "Output a CSV with columns is_external, time_ms, 80.0 and 95.0 for each item in buckets, combining fields from both latest.hits.hits and perf_QS_percentiles.values.",
    "expressions": [
      ".buckets[] | (.latest.hits.hits[]._source | [.\"is_external\", .\"time_ms\"]) + (.perf_QS_percentiles.values | [.\"80.0\", .\"95.0\"]) | @csv"
    ],
    "data": [
      {
        "input": {
          "buckets": [
            {
              "perf_SP_percentiles": {
                "values": {
                  "80.0": 0,
                  "95.0": 0
                }
              },
              "perf_QS_percentiles": {
                "values": {
                  "80.0": 12309620299487,
                  "95.0": 12309620299487
                }
              },
              "latest": {
                "hits": {
                  "total": 3256,
                  "max_score": null,
                  "hits": [
                    {
                      "_source": {
                        "is_external": true,
                        "time_ms": 1492110000000
                      },
                      "sort": [
                        1492110000
                      ]
                    }
                  ]
                }
              }
            }
          ]
        },
        "output": [
          "true,1492110000000,12309620299487,12309620299487"
        ]
      }
    ],
    "identifier": 43503155
  },
  {
    "context": [
      "This is the JSON cURL passes to jq (and, FTR, I want jq to return \"VALUE-I-WANT\" without the quotation marks):",
      "[  ",
      "   {  ",
      "      \"success\":{  ",
      "         \"username\":\"VALUE-I-WANT\"",
      "      }",
      "   }",
      "]",
      "I initially tried this:",
      "jq ' . | .success | .username'",
      "and got",
      "jq: error (at <stdin>:0): Cannot index array with string \"success\"",
      "They didn't return an error, they returned \"null\". Which may or may not be an improvement.",
      "You need to *pipe* the output of `.[]` into the next filter.",
      "jq -r '.[] | .success.username' tmp.json",
      "jq -r '.[].success.username' file.json",
      "jq -r '.[0].success.username' file.json",
      "Thus, simply replacing `. |` with `.[] |` in your original attempt, combined with `-r` to get _raw_ (unquoted output), should solve your problem, as shown in [chepner's helpful answer](https://stackoverflow.com/a/43553367/45375)."
    ],
    "utterance": "Extract the value of success.username from each element in the top-level array, outputting it without quotation marks.",
    "expressions": [
      ".[] | .success.username",
      ".[].success.username",
      ".[0].success.username"
    ],
    "data": [
      {
        "input": [
          {
            "success": {
              "username": "VALUE-I-WANT"
            }
          }
        ],
        "output": "VALUE-I-WANT"
      }
    ],
    "identifier": 43553348
  },
  {
    "context": [
      "Using Jq how to add sub person to the main Json so that desired output is\n\n    {\n    \t\"person\": [{\n    \t\t\t\"name\": \"John\",\n    \t\t\t\"Age\": 10\n    \t\t},\n    \t\t{\n    \t\t\t\"name\": \"smith\",\n    \t\t\t\"Age\": 20\n    \t\t}\n    \t],\n    \t\"Work\": [{\n    \t\t\"Type\": \"HR\"\n    \t}]\n    }",
      "the desired result can be obtained by using `+=`, which is analogous to += in other languages, but here uses addition of arrays in the sense of concatenation:",
      ".person += $sub.person",
      "jq --argfile sub Sub.json '.person += $sub.person' Main.json",
      "jq -s '.[1] as $sub | .[0]|.person += $sub.person'  Main.json Sub.json"
    ],
    "utterance": "Add the person array from the second file to the person array in the first file, preserving the Work array.",
    "expressions": [
      ".person += $sub.person",
      ".[1] as $sub | .[0]|.person += $sub.person"
    ],
    "data": [
      {
        "input": {
          "main": {
            "person": [
              {
                "name": "John",
                "Age": 10
              }
            ],
            "Work": [
              {
                "Type": "HR"
              }
            ]
          },
          "sub": {
            "person": [
              {
                "name": "smith",
                "Age": 20
              }
            ]
          }
        },
        "output": {
          "person": [
            {
              "name": "John",
              "Age": 10
            },
            {
              "name": "smith",
              "Age": 20
            }
          ],
          "Work": [
            {
              "Type": "HR"
            }
          ]
        }
      }
    ],
    "identifier": 43548387
  },
  {
    "context": [
      "jq has a built-in filter, `input_line_number`, which emits the line number of the input being read.",
      "the invocation:\r\n\r\n    jq -r \"\\(input_line_number): \\(length)\" \r\n\r\nyields:\r\n\r\n    1: 2\r\n    3: 4\r\n    5: 5"
    ],
    "utterance": "Display the line number and the length of each line in the file.",
    "expressions": [
      "\"\\(input_line_number): \\(length)\""
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          "abcd",
          {
            "a": 1,
            "b": 1,
            "c": 1,
            "d": 1,
            "e": 1
          }
        ],
        "output": [
          "1: 2",
          "3: 4",
          "5: 5"
        ]
      }
    ],
    "identifier": 43594976
  },
  {
    "context": [
      "I would like to use the headers section as keys for each row. So the output should look like this:",
      "With `convolve/1` as defined, we can now create the array of objects:\n\n        .headers as $h | .rows | map( convolve($h) )",
      "Here is a solution which uses a recursive function **obj** to build an object from arrays of keys and values.\n\n    def obj($keys; $values):\n        if   $keys|length < 1\n        then {} \n        else {($keys[0]): $values[0]} + obj($keys[1:]; $values[1:])\n        end\n    ;\n\n    [ obj(.headers; .rows[]) ]"
    ],
    "utterance": "Produce an array of objects pairing each header as a key with the corresponding value from each row.",
    "expressions": [
      "def convolve(headers):\n  . as $in\n  | reduce range(0; length) as $i ({}; . + {(headers[$i]): $in[$i]} );\n\n.headers as $h | .rows | map( convolve($h) )",
      "def convolve(headers):\n  [., headers] | transpose | map( {(.[0]): .[1]} ) | add;\n\n.headers as $h | .rows | map( convolve($h) )",
      ".headers as $h | reduce .rows[] as $row ([]; . + [$row|convolve($h)])",
      "def obj($keys; $values):\n  if $keys|length < 1 then {} else {($keys[0]): $values[0]} + obj($keys[1:]; $values[1:]) end;\n\n[ obj(.headers; .rows[]) ]"
    ],
    "data": [
      {
        "input": {
          "headers": [
            "key1",
            "key2",
            "key3"
          ],
          "rows": [
            [
              "value1",
              "value2",
              "value3"
            ],
            [
              "value1",
              "value2",
              "value3"
            ],
            [
              "value1",
              "value2",
              "value3"
            ]
          ],
          "total_rows": "3"
        },
        "output": [
          {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          }
        ]
      }
    ],
    "identifier": 43545806
  },
  {
    "context": [
      "what I would like to do, is transform each object, where apart from the small adjustments, the node named last, adds the length nodes, so as in the end, we have the sum of lengths, for each part:",
      "Desired JSON output:",
      "def part: \n  { (.serialnumber):\n      {position_in,\n       duplicate,\n       last: (.positions | map(.length) | add) }};",
      "{ (.serialnumber): { duplicate, \"parts\": (.parts | map(part) ) } }"
    ],
    "utterance": "Transform objects so that each part has a 'last' field which is the sum of all 'length' values in its positions, and restructure the output as shown in the desired output.",
    "expressions": [
      "def part: { (.serialnumber): {position_in, duplicate, last: (.positions | map(.length) | add) }}; { (.serialnumber): { duplicate, \"parts\": (.parts | map(part) ) } }"
    ],
    "data": [
      {
        "input": {
          "serialnumber": "5690",
          "duplicate": true,
          "parts": [
            {
              "serialnumber": "43",
              "position_in": true,
              "duplicate": true,
              "positions": [
                {
                  "self": 0,
                  "length": 3
                },
                {
                  "self": 4,
                  "length": 1
                },
                {
                  "self": 5,
                  "length": 2
                }
              ]
            },
            {
              "serialnumber": "745",
              "position_in": true,
              "duplicate": false,
              "positions": [
                {
                  "self": 0,
                  "length": 8
                },
                {
                  "self": 8,
                  "length": 1
                },
                {
                  "self": 9,
                  "length": 1
                }
              ]
            }
          ]
        },
        "output": {
          "5690": {
            "duplicate": true,
            "parts": [
              {
                "43": {
                  "position_in": true,
                  "duplicate": true,
                  "last": 6
                }
              },
              {
                "745": {
                  "position_in": true,
                  "duplicate": false,
                  "last": 10
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 43588044
  },
  {
    "context": [
      "The query path I could do it but I'm not sure how to get the output of `jq` to `curl`",
      "And this is the results I got",
      "[\n  \"10.xx.xx.xxx\",\n  \"10.xx.xx.xxx\",\n]",
      "What I would like it to be is",
      "`curl http://10.xx.xx.xxx:8081/version`"
    ],
    "utterance": "For each IP address output, generate a command to access the resource at http://<ip>:8081/version.",
    "expressions": [
      ".[] | \"curl http://\"+.+\":8081/version\""
    ],
    "data": [
      {
        "input": [
          "10.0.0.1",
          "10.0.0.2"
        ],
        "output": [
          "curl http://10.0.0.1:8081/version",
          "curl http://10.0.0.2:8081/version"
        ]
      }
    ],
    "identifier": 43625589
  },
  {
    "context": [
      "I need to pull a substring from JSON.  In the JSON doc below, I need the end of the value of `jq '.[].networkProfile.networkInterfaces[].id'`  In other words, I need just `A10NICvw4konls2vfbw-data` to pass to another command.",
      "In your case, `sub(\".*/\";\"\")` will do the trick as * is greedy:",
      ".[].networkProfile.networkInterfaces[].id | sub(\".*/\";\"\")",
      "Try this:",
      "jq -r '.[]|.networkProfile.networkInterfaces[].id | split(\"/\") | last'"
    ],
    "utterance": "Extract only the final portion after the last slash from the id field within all networkProfile.networkInterfaces arrays.",
    "expressions": [
      ".[].networkProfile.networkInterfaces[].id | sub(\".*/\";\"\")",
      ".[] | .networkProfile.networkInterfaces[].id | split(\"/\") | last"
    ],
    "data": [
      {
        "input": [
          {
            "id": "/subscriptions/blah/resourceGroups/IPv6v2/providers/Microsoft.Compute/virtualMachines/A10VNAvw4konls2vfbw",
            "instanceView": null,
            "licenseType": null,
            "location": "centralus",
            "name": "A10VNAvw4konls2vfbw",
            "networkProfile": {
              "networkInterfaces": [
                {
                  "id": "/subscriptions/blah/resourceGroups/IPv6v2/providers/Microsoft.Network/networkInterfaces/A10NICvw4konls2vfbw-data",
                  "resourceGroup": "IPv6v2"
                }
              ]
            }
          }
        ],
        "output": "A10NICvw4konls2vfbw-data"
      }
    ],
    "identifier": 43595121
  },
  {
    "context": [
      "For example, in each row, I want to write the output of date +%F before the UUID, Sitename and Jar values.  Is it possible?",
      "If your jq is sufficiently recent, use jq's time-and-date functions, starting with `now`:",
      "$ jq -n 'now|strftime(\"%Y-%m-%d\")'",
      "Pass the date string in to jq using a suitable command-line option, e.g.",
      "$ jq -n --arg date \"$(date +%F)\" '$date'"
    ],
    "utterance": "Prepend the current date in YYYY-MM-DD format as the first value of each output row before the other selected fields.",
    "expressions": [
      "[(now|strftime(\"%Y-%m-%d\")), .[\"_uuid\"], .[\"site_name\"], .[\"Jar\"]] + (.PS_percentiles.values | [.\"80.0\", .\"95.0\"]) | @csv",
      "[ $date, .[\"_uuid\"], .[\"site_name\"], .[\"Jar\"] ] + (.PS_percentiles.values | [.\"80.0\", .\"95.0\"]) | @csv"
    ],
    "identifier": 43597719
  },
  {
    "context": [
      "jq -r '.dependencies,.devDependencies|keys[]' $< | while read -r dep; do \\",
      "[ -f \"$$dep/package.json\" ] && echo \"$$dep\"; \\",
      "So I am trying to run a jq command inside a makefile to link some dependencies",
      "echo \"$$dep\" I understand what's going on, but when using the full line of code ([ -f \"$$dep/package.json\" ] && echo \"$$dep\";) I seem to be lost.",
      "'.dependencies,.devDependencies|keys[]'"
    ],
    "utterance": "List all keys from the dependencies and devDependencies properties.",
    "expressions": [
      ".dependencies, .devDependencies | keys[]",
      ".dependencies // {} , .devDependencies // {} | keys[]"
    ],
    "identifier": 43659066
  },
  {
    "context": [
      "I would like to have JQ print out arrays on a single line. My input is a an Avro schema that I want to normalize.",
      "I would like to able to display this:\n\n    {\n      \"name\": \"rm\",\n      \"fields\": [\n        {\n          \"name\": \"stat_1\",\n          \"type\": \"long\"\n        },\n        {\n          \"name\": \"stat_2\",\n          \"type\": [\n            \"long\",\n            \"null\"\n          ]\n        }\n      ]\n    }\n\nlike this:\n\n    {\n      \"name\": \"rm\",\n      \"fields\": [\n        {\n          \"name\": \"stat_1\",\n          \"type\": \"long\"\n        },\n        {\n          \"name\": \"stat_2\",\n          \"type\": [\"long\", \"null\"]  << FLATTENED\n        }\n      ]\n    }",
      "walk(if type == \"array\" and all(.[]|type; . != \"array\" and . != \"object\") then tostring else . end)",
      "If your jq has isempty (or if you don't mind adding its definition, e.g. to your ~/.jq), the above can be shortened to:\n\n    walk(if type == \"array\" and isempty(.[]|iterables) then tostring else . end)"
    ],
    "utterance": "Display all arrays of scalars on a single line in the output to make diffs cleaner when normalizing Avro schemas.",
    "expressions": [
      "walk(if type == \"array\" and all(.[]|type; . != \"array\" and . != \"object\") then tostring else . end)",
      "walk(if type == \"array\" and isempty(.[]|iterables) then tostring else . end)"
    ],
    "data": [
      {
        "input": {
          "name": "rm",
          "fields": [
            {
              "name": "stat_1",
              "type": "long"
            },
            {
              "name": "stat_2",
              "type": [
                "long",
                "null"
              ]
            }
          ]
        },
        "output": {
          "name": "rm",
          "fields": [
            {
              "name": "stat_1",
              "type": "long"
            },
            {
              "name": "stat_2",
              "type": "[\"long\",\"null\"]"
            }
          ]
        }
      }
    ],
    "identifier": 43665877
  },
  {
    "context": [
      "I want to end up with the following:-\n\n    {\n      \"type\": \"FeatureCollection\",\n      \"features\": [\n       {\n         \"tippecanoe\" : {\"minzoom\" : 13},\n         \"type\": \"Feature\",\n         \"properties\": {\n         \"FEATCODE\": 15014\n      },\n      \"geometry\": {\n        \"type\": \"Polygon\",\n        \"coordinates\": [\n         .....",
      "ie. I have added the tippecanoe object to each feature in the array **features**",
      "jq '.features[].tippecanoe.minzoom = 13'",
      "An alternative solution could be for example:\n\n    jq '.features |= map_values(.tippecanoe.minzoom = 13)'",
      "In this case, `map` rather than `map_values` is far faster (*): \n\n    .features |= map(.tippecanoe.minzoom = 13)",
      "A one-pass jq-only approach may require more RAM than is available.  If that is the case, then a simple all-jq approach is shown below, together with a more economical approach based on using jq along with awk.",
      "jq -c  '.features[]' input.json |\n    jq -c '.tippecanoe.minzoom = 13' |\n    jq -c -s '{type: \"FeatureCollection\", features: .}'"
    ],
    "utterance": "Add the object {\"tippecanoe\": {\"minzoom\": 13}} to each element in the features array where each feature is an object in a FeatureCollection.",
    "expressions": [
      ".features |= map(.tippecanoe.minzoom = 13)",
      ".features |= map_values(.tippecanoe.minzoom = 13)",
      "jq -c '.features[]' input.json | jq -c '.tippecanoe.minzoom = 13' | jq -c -s '{type: \"FeatureCollection\", features: .}'"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "FEATCODE": 15014
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    []
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "FEATCODE": 15099
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    []
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "FEATCODE": 15014
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    []
                  ]
                ]
              },
              "tippecanoe": {
                "minzoom": 13
              }
            },
            {
              "type": "Feature",
              "properties": {
                "FEATCODE": 15099
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    []
                  ]
                ]
              },
              "tippecanoe": {
                "minzoom": 13
              }
            }
          ]
        }
      }
    ],
    "identifier": 43469103
  },
  {
    "context": [
      "What I am actually hoping to achieve (recursively copy the values of all `numberLong` keys one level up, regardless of where they belong in the file)",
      "If your jq has 'walk/1' then the simplest completely generic solution would be along these lines:",
      "    walk( if type==\"object\"\n          then with_entries( if .value | (type == \"object\" and has(\"numberLong\"))\n                             then .value |= .numberLong\n                             else . end)\n          else . end )"
    ],
    "utterance": "Replace all objects containing only the key 'numberLong' with their contained value, at any nesting depth.",
    "expressions": [
      "walk(if type==\"object\" then with_entries(if .value | (type == \"object\" and has(\"numberLong\")) then .value |= .numberLong else . end) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "age": {
              "numberLong": 22
            }
          },
          {
            "name": "Jane",
            "age": 24
          },
          {
            "name": "Dennis",
            "age": 34,
            "details": [
              {
                "telephone_number": 555124124
              }
            ]
          },
          {
            "name": "Frances",
            "details": [
              {
                "telephone_number": {
                  "numberLong": 444245523
                }
              }
            ]
          }
        ],
        "output": [
          {
            "name": "John",
            "age": 22
          },
          {
            "name": "Jane",
            "age": 24
          },
          {
            "name": "Dennis",
            "age": 34,
            "details": [
              {
                "telephone_number": 555124124
              }
            ]
          },
          {
            "name": "Frances",
            "details": [
              {
                "telephone_number": 444245523
              }
            ]
          }
        ]
      }
    ],
    "identifier": 43739846
  },
  {
    "context": [
      "I\u2019m in need to extract the key, based on the value of name, ie. I\u2019m searching for ```\"after-sshd-fixes\"``` and then want ```\"{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}\"``` as output.",
      "jq 'to_entries[] | select(.value.name == \"after-sshd-fixes\").key' jsonfile",
      "The output:\n\n    \"{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}\""
    ],
    "utterance": "Extract the object key whose nested property 'name' equals \"after-sshd-fixes\".",
    "expressions": [
      "to_entries[] | select(.value.name == \"after-sshd-fixes\").key"
    ],
    "data": [
      {
        "input": {
          "{c156e78e-a4ac-422b-bf86-afe12f548dfb}": {
            "name": "after-gluster3.8",
            "date": "2017-04-16 14:31:20",
            "state": "poweron",
            "current": false,
            "parent": ""
          },
          "{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}": {
            "name": "after-sshd-fixes",
            "date": "2017-04-16 16:58:32",
            "state": "poweroff",
            "current": true,
            "parent": "{c156e78e-a4ac-422b-bf86-afe12f548dfb}"
          }
        },
        "output": "\"{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}\""
      }
    ],
    "identifier": 43678724
  },
  {
    "context": [
      "> to select the name of entry which has aNo = 66",
      "jq '.[] | select(.aNo == 66).name' file.json",
      "The output:",
      "\"Fella\"",
      "cat file.json | jq -s | jq -r '.[]|select(.aNo == 66).name'",
      "Fella"
    ],
    "utterance": "Select the name value for the object where aNo equals 66.",
    "expressions": [
      ".[] | select(.aNo == 66).name",
      ".[] | select(.aNo == 66) | .name",
      ".[] | select(.aNo == 66) | .[\"name\"]"
    ],
    "data": [
      {
        "input": [
          {
            "aNo": 66,
            "name": "Fella"
          },
          {
            "aNo": 77,
            "name": "Bella"
          }
        ],
        "output": "Fella"
      }
    ],
    "identifier": 43784145
  },
  {
    "context": [
      "Normal command line JQ works with Curl and gives output as follows:",
      "curl --basic -u admin:admin http://localhost:9090/mmc-console-3.8.2/api/deployments | jq \".data[] | select(.name==\\\"test-mmc-deploy\\\").id",
      "\"local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4\"",
      "Running this directly in a command prompt works for me:",
      "jq \".data[] | select(.name==\\\"test-mmc-deploy\\\").id input.json",
      "For /f \"tokens=*\" %%a in ('curl --basic -u admin:admin http://localhost:9090/mmc-console-3.8.2/api/deployments ^| jq \".data[] | select(.name==\\\"test-mmc-deploy\\\").id' ) do ( set app_id=%%a )"
    ],
    "utterance": "Extract the id field from each object in data where name equals \"test-mmc-deploy\".",
    "expressions": [
      ".data[] | select(.name==\"test-mmc-deploy\").id"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "test-mmc-deploy",
              "id": "local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4",
              "lastModified": "Mon, 1 May 2017 13:56:15.980 AEST",
              "servers": [
                "local$520ee705-bdbb-4132-94cf-63bb213d2b46"
              ],
              "status": "DEPLOYED",
              "applications": [
                "local$f3d791bd-14d9-4491-9541-5fa04d8c3164"
              ],
              "href": "http://localhost:9090/mmc-console-3.8.2/api/deployments/local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4",
              "clusterNames": [],
              "reconciled": false,
              "clusterIds": []
            }
          ]
        },
        "output": "local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4"
      }
    ],
    "identifier": 43728994
  },
  {
    "context": [
      "I would like to convert that array into something like this:",
      "{\n  \"Config\": {\n    \"Env\": {\n      \"JENKINS_HOST\": \"1.2.3.4\",\n      \"JENKINS_INSTANCE\": \"tea\",\n      \"JENKINS_NAME\": \"Enterprise Architecture Tools\",\n      \"JENKINS_VERSION\": \"2.46.2\",\n      \"JENKINS_PROTOCOL\": \"http\"\n    }\n  }\n}",
      "map(.Config.Env |= (map( split(\"=\") | { (.[0]) : .[1] } ) | add))",
      "def a2o: map( split(\"=\") | { (.[0]) : .[1] } ) | add;",
      "map(.Config.Env |= a2o)",
      "reduce (.[] | split(\"=\")) as [$key, $value] ({}; .[$key] = $value)",
      ".[].Config.Env |= reduce (.[] | split(\"=\")) as [$key, $value] ({}; .[$key] = $value)",
      ".[].Config.Env |= (map(split(\"=\") as [$key, $value] | {$key, $value}) | from_entries)"
    ],
    "utterance": "Transform the Env array of 'VAR=VALUE' strings inside Config to an object with variable names as keys and their values as values.",
    "expressions": [
      "map(.Config.Env |= (map( split(\"=\") | { (.[0]) : .[1] } ) | add))",
      "def a2o: map( split(\"=\") | { (.[0]) : .[1] } ) | add; map(.Config.Env |= a2o)",
      ".[].Config.Env |= reduce (.[] | split(\"=\")) as [$key, $value] ({}; .[$key] = $value)",
      ".[].Config.Env |= (map(split(\"=\") as [$key, $value] | {$key, $value}) | from_entries)"
    ],
    "data": [
      {
        "input": [
          {
            "Config": {
              "Env": [
                "JENKINS_HOST=1.2.3.4",
                "JENKINS_INSTANCE=tea",
                "JENKINS_NAME=Enterprise Architecture Tools",
                "JENKINS_VERSION=2.46.2",
                "JENKINS_PROTOCOL=http"
              ]
            }
          }
        ],
        "output": [
          {
            "Config": {
              "Env": {
                "JENKINS_HOST": "1.2.3.4",
                "JENKINS_INSTANCE": "tea",
                "JENKINS_NAME": "Enterprise Architecture Tools",
                "JENKINS_VERSION": "2.46.2",
                "JENKINS_PROTOCOL": "http"
              }
            }
          }
        ]
      }
    ],
    "identifier": 43729643
  },
  {
    "context": [
      "My input,\r\n\r\n    [1, 2, 3, 4, 5]",
      "And I have a **\"whitelist\"**:\r\n\r\n    [3, 4, 7]",
      "I need to filter input list through whitelist. **Expected output**:\r\n\r\n    [3, 4]",
      "How do I filter using a whitelist?",
      "Changed `contains` for `inside` and it seems to work now:\r\n\r\n    $ jq --compact-output --null-input '[1,2,3,4,5] | map(select([.] | inside([3,4,7])))'\r\n    [3,4]",
      "The filter you'd use with `contains` is:\r\n\r\n    map(. as $x | select([3,4,7] | contains([$x])))",
      "If the whitelist is available as $whitelist and if you want to use map(select(...)), an appropriate filter would be:\r\n\r\n    map( . as $x | select($whitelist|index($x)))"
    ],
    "utterance": "Filter a list, returning only items that appear in a given whitelist, where the input is [1,2,3,4,5] and the whitelist is [3,4,7], so the output should be [3,4].",
    "expressions": [
      "[1,2,3,4,5] | map(select([.] | inside([3,4,7])))",
      "[1,2,3,4,5] | map(. as $x | select([3,4,7] | contains([$x])))",
      "([1,2,3,4,5] | map(. as $x | select($whitelist | index($x))))"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          5
        ],
        "output": [
          3,
          4
        ]
      }
    ],
    "identifier": 43833974
  },
  {
    "context": [
      "I use this command",
      ".[] | .\"CloudSanityPassed\" | .[]",
      "I get, what I want (\"true\" value), but there is a error in output. Could you explain me, how to avoid it and why does it happen?",
      "Maybe the command you want is just `.properties.CloudSanityPassed`."
    ],
    "utterance": "Extract the CloudSanityPassed property value from the properties object.",
    "expressions": [
      ".properties.CloudSanityPassed"
    ],
    "data": [
      {
        "input": {
          "properties": {
            "CloudSanityPassed": [
              "true"
            ],
            "GITCOMMIT": [
              "test1"
            ],
            "buildNumber": [
              "54"
            ],
            "jobName": [
              "InveergDB-UI"
            ]
          },
          "uri": "http://ergctory:8081/aergergory/api/storage/test-reergerglease-reergpo/cergom/cloergud/waf/ergregBUI/1ergerggregSHOT/ergregerg-34.zip"
        },
        "output": [
          "true"
        ]
      }
    ],
    "identifier": 43842672
  },
  {
    "context": [
      "I want to extract all objects, that have a certain ID. I managed to get an object if I want just one specific ID: `jq 'map(select(.id == 2 ))' test.json`.",
      "Thing is, I have a list of IDs, say 1 and 3. How do I get a list containing only those object? So in this example a list containing the objects with ID 1 and 3?",
      "`jq 'map(select(.id | contains(1,3)))'`",
      "The solution using `contains/1` as presented on this page could just as well be written using `==`:",
      "    map(select(.id == (1,3)))"
    ],
    "utterance": "Return all objects whose id is 1 or 3 from the array.",
    "expressions": [
      "map(select(.id | contains(1,3)))",
      "map(select(.id == (1,3)))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Test 1",
            "id": 1
          },
          {
            "name": "Test 2",
            "id": 2
          },
          {
            "name": "Test 3",
            "id": 3
          }
        ],
        "output": [
          {
            "name": "Test 1",
            "id": 1
          },
          {
            "name": "Test 3",
            "id": 3
          }
        ]
      }
    ],
    "identifier": 43851953
  },
  {
    "context": [
      "With `jq-1.5` (the most recent version atm) you can do:",
      "jq 'if .dm == \"-\" then .dm = (.url|sub(\"https?://\";\"\")|sub(\"/.*\";\"\")) else . end' a.json",
      "if .dm == \"-\" ...           # Runs the following only if .dm exists and it's value is \"-\"",
      ".dm=(...)                   # Assigns to .dm",
      ".url|sub(\"^https?://\"; \"\")  # Takes .url and replaces http/https:// from the beginning",
      "...|sub(\"/.*\"; \"\")          # Replaces everything after the first / (including it)"
    ],
    "utterance": "Replace the value of the dm field with the domain extracted from the url field for records where dm is \"-\"; leave other lines unchanged.",
    "expressions": [
      "if .dm == \"-\" then .dm = (.url|sub(\"https?://\";\"\")|sub(\"/.*\";\"\")) else . end"
    ],
    "data": [
      {
        "input": [
          {
            "id": 13,
            "url": "https://sub.domain.com/path",
            "dm": "-",
            "ip": "192.168.0.1"
          },
          {
            "id": 14,
            "url": "sub.domain2.com/?param=value",
            "dm": "-",
            "ip": "192.168.0.1"
          },
          {
            "id": 15,
            "url": "domain.com/path",
            "dm": "prefilled.com",
            "ip": "192.168.0.1"
          }
        ],
        "output": [
          {
            "id": 13,
            "url": "https://sub.domain.com/path",
            "dm": "sub.domain.com",
            "ip": "192.168.0.1"
          },
          {
            "id": 14,
            "url": "sub.domain2.com/?param=value",
            "dm": "sub.domain2.com",
            "ip": "192.168.0.1"
          },
          {
            "id": 15,
            "url": "domain.com/path",
            "dm": "prefilled.com",
            "ip": "192.168.0.1"
          }
        ]
      }
    ],
    "identifier": 43896931
  },
  {
    "context": [
      "I have multiple JSON files that I'd like to merge into one.",
      "Some have the same root element but different children. I don't want to overwrite the children but too extend them if they have the same parent element.",
      "Here is a recursive solution which uses `group_by(.key)` to decide\nwhich objects to combine.  This could be a little simpler if `.children`\nwere more uniform.",
      "When run with the `-s` option as follows\n\n    jq -M -s -f filter.jq file1.json file2.json\n\nIt produces the following output.",
      "[\n  {\n    \"title\": \"Title1\",\n    \"key\": \"12345678\",\n    \"children\": [\n      {\n        \"title\": \"SubTitle2\",\n        \"key\": \"123456713\",\n        \"children\": [\n          {}\n        ]\n      },\n      {\n        \"title\": \"SubTitle1\",\n        \"key\": \"12345679\",\n        \"children\": [\n          {\n            \"title\": \"SubSubTitle1\",\n            \"key\": \"12345610\"\n          },\n          {\n            \"title\": \"SubSubTitle2\",\n            \"key\": \"12345611\"\n          },\n          {\n            \"title\": \"DifferentSubSubTitle1\",\n            \"key\": \"12345612\"\n          }\n        ]\n      }\n    ]\n  }\n]"
    ],
    "utterance": "Combine multiple files, merging arrays of objects at each parent based on shared key, so that children from both sources are included under parents with the same key without overwriting.",
    "expressions": [
      "def merge:\n    def kids:\n        map(\n            .children\n          | if length<1 then empty else .[] end\n        )\n      | if length<1 then {} else {children:merge} end\n    ; \n    def mergegroup:\n      {\n          title: .[0].title\n        , key:   .[0].key\n      } + kids\n    ;\n    if   .==[{}] then .\n    else group_by(.key) | map(mergegroup)\n    end\n;\n[ .[] | .[] ] | merge"
    ],
    "data": [
      {
        "input": [
          [
            {
              "title": "Title1",
              "key": "12345678",
              "children": [
                {
                  "title": "SubTitle1",
                  "key": "12345679",
                  "children": [
                    {
                      "title": "SubSubTitle1",
                      "key": "12345610"
                    },
                    {
                      "title": "SubSubTitle2",
                      "key": "12345611"
                    }
                  ]
                }
              ]
            }
          ],
          [
            {
              "title": "Title1",
              "key": "12345678",
              "children": [
                {
                  "title": "SubTitle2",
                  "key": "123456713",
                  "children": [
                    {}
                  ]
                },
                {
                  "title": "SubTitle1",
                  "key": "12345679",
                  "children": [
                    {
                      "title": "DifferentSubSubTitle1",
                      "key": "12345612"
                    }
                  ]
                }
              ]
            }
          ]
        ],
        "output": [
          {
            "title": "Title1",
            "key": "12345678",
            "children": [
              {
                "title": "SubTitle2",
                "key": "123456713",
                "children": [
                  {}
                ]
              },
              {
                "title": "SubTitle1",
                "key": "12345679",
                "children": [
                  {
                    "title": "SubSubTitle1",
                    "key": "12345610"
                  },
                  {
                    "title": "SubSubTitle2",
                    "key": "12345611"
                  },
                  {
                    "title": "DifferentSubSubTitle1",
                    "key": "12345612"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 43764041
  },
  {
    "context": [
      "I am trying to extract the string `us-east-1:ami-a3159eb2` only using `jq`.",
      "Use `select` to filter a specific document : \r\n\r\n    jq -r '.last_run_uuid as $uuid | .builds[] | select(.packer_run_uuid == $uuid) | .artifact_id' data.json\r\n",
      ".last_run_uuid as $last | .builds[] | select( $last == .packer_run_uuid) | .artifact_id"
    ],
    "utterance": "Extract the artifact_id value where packer_run_uuid matches last_run_uuid.",
    "expressions": [
      ".last_run_uuid as $uuid | .builds[] | select(.packer_run_uuid == $uuid) | .artifact_id",
      ".last_run_uuid as $last | .builds[] | select($last == .packer_run_uuid) | .artifact_id",
      "[\"last_run_uuid\"] as $last | .builds[] | select($last == .[\"packer_run_uuid\"]) | .artifact_id"
    ],
    "data": [
      {
        "input": {
          "builds": [
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490743286,
              "files": null,
              "artifact_id": "us-east-1:ami-ae4af3b8",
              "packer_run_uuid": "76afaf47-2ac2-8b50-da43-ea5bff541ae6"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490744203,
              "files": null,
              "artifact_id": "us-east-1:ami-994ff68f",
              "packer_run_uuid": "d5655333-4240-bbf5-8b08-94be7606536d"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490744956,
              "files": null,
              "artifact_id": "us-east-1:ami-e241f8f4",
              "packer_run_uuid": "5f7efb09-4b45-9239-ffe6-903a0aed26e4"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490745669,
              "files": null,
              "artifact_id": "us-east-1:ami-4046ff56",
              "packer_run_uuid": "69fd6d30-fdfd-6778-54ac-338abbea2d88"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490746077,
              "files": null,
              "artifact_id": "us-east-1:ami-dc3b82ca",
              "packer_run_uuid": "4c74241d-f7e2-bdad-6fa7-3fb84e56c9b3"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1490806537,
              "files": null,
              "artifact_id": "us-east-1:ami-2c4cf43a",
              "packer_run_uuid": "afcbe826-1a0a-7042-35cb-3e3c2569b48b"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1491921968,
              "files": null,
              "artifact_id": "us-east-1:ami-69a8207f",
              "packer_run_uuid": "57ad32f1-6291-7a60-5ee9-3bf46aacd288"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1491940019,
              "files": null,
              "artifact_id": "us-east-1:ami-035ad215",
              "packer_run_uuid": "a0124439-8002-9d13-59bf-43fdcef6eb5e"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1491940543,
              "files": null,
              "artifact_id": "us-east-1:ami-7e5fd768",
              "packer_run_uuid": "42a0f104-460f-789a-6a86-37ea6b9fbf93"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1491941479,
              "files": null,
              "artifact_id": "us-east-1:ami-0252da14",
              "packer_run_uuid": "13fd9737-e41f-ce82-b991-b363fae971b5"
            },
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1492026265,
              "files": null,
              "artifact_id": "us-east-1:ami-a3159eb2",
              "packer_run_uuid": "83d55673-620e-05ee-2983-24cab0a009d5"
            }
          ],
          "last_run_uuid": "83d55673-620e-05ee-2983-24cab0a009d5"
        },
        "output": "us-east-1:ami-a3159eb2"
      }
    ],
    "identifier": 43454997
  },
  {
    "context": [
      "I need the value of `DATABASES_DEFAULT` where the `name` is `baz`. Note that there are a lot of keypairs with `name`, I'm specifically talking about the one outside of `environment`.",
      ".taskDefinition.containerDefinitions[] |\nselect(.name ==\"baz\")                  |\n.environment[]                         |\nselect(.name == \"DATABASES_DEFAULT\")   |\n.value",
      "Output:\n\n    \"foo\""
    ],
    "utterance": "Return the value where the environment variable name is DATABASES_DEFAULT inside the container definition whose name is baz.",
    "expressions": [
      ".taskDefinition.containerDefinitions[] | select(.name == \"baz\") | .environment[] | select(.name == \"DATABASES_DEFAULT\") | .value"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "status": "bar",
            "family": "bar2",
            "volumes": [],
            "taskDefinitionArn": "bar3",
            "containerDefinitions": [
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "bar4",
                    "value": "bar5"
                  },
                  {
                    "name": "bar6",
                    "value": "bar7"
                  },
                  {
                    "name": "DATABASES_DEFAULT",
                    "value": "foo"
                  }
                ],
                "name": "baz",
                "links": []
              },
              {
                "dnsSearchDomains": [],
                "environment": [
                  {
                    "name": "bar4",
                    "value": "bar5"
                  },
                  {
                    "name": "bar6",
                    "value": "bar7"
                  },
                  {
                    "name": "DATABASES_DEFAULT",
                    "value": "foo2"
                  }
                ],
                "name": "boo",
                "links": []
              }
            ],
            "revision": 1
          }
        },
        "output": "foo"
      }
    ],
    "identifier": 43924402
  },
  {
    "context": [
      "I'd like to write two log files using tee, first log file as txt, second log file as json",
      "Tee is working for two txt files, but can't get jq to work with tee...",
      "echo \"start process $(date -u)\" | tee -a $logfilename.txt >> jq . $logfilename.json",
      "Based on your description, it looks like you want:",
      "echo \"start process $(date -u)\" | tee -a \"$logfilename.txt\" | jq . >> \"$logfilename.json\""
    ],
    "utterance": "Write output to a text log file while also writing the same output, processed through jq, to a JSON log file.",
    "expressions": [
      "echo \"start process $(date -u)\" | tee -a \"$logfilename.txt\" | jq . >> \"$logfilename.json\""
    ],
    "identifier": 43971184
  },
  {
    "context": [
      "What's a `jq` filter for obtaining the value of the payload in the \"path\" aaa/bbb/ccc/ddd?",
      "jq '.subs[] | select(.name = \"aaa\") | .subs[] | select(.name = \"bbb\") | .subs[] | select(.name = \"ccc\") | .subs[] | .payload'",
      "def descend(name): .subs[] | select(.name == name);",
      "descend( \"aaa\") | descend( \"bbb\") | descend( \"ccc\") | descend( \"ddd\") | .payload",
      "def path(array): \n  if (array|length)==0 then . \n  else descend(array[0]) | path(array[1:])\n  end;\n\npath( [\"aaa\", \"bbb\", \"ccc\", \"ddd\"] ) | .payload"
    ],
    "utterance": "Retrieve the payload value at the nested location identified by the name path: aaa, then bbb, then ccc, then ddd.",
    "expressions": [
      ".subs[] | select(.name == \"aaa\") | .subs[] | select(.name == \"bbb\") | .subs[] | select(.name == \"ccc\") | .subs[] | select(.name == \"ddd\") | .payload",
      "def descend(name): .subs[] | select(.name == name); descend(\"aaa\") | descend(\"bbb\") | descend(\"ccc\") | descend(\"ddd\") | .payload",
      "def descend(name): .subs[] | select(.name == name); def path(array): if (array|length)==0 then . else descend(array[0]) | path(array[1:]) end; path([\"aaa\", \"bbb\", \"ccc\", \"ddd\"]) | .payload"
    ],
    "data": [
      {
        "input": {
          "subs": [
            {
              "name": "aaa",
              "subs": [
                {
                  "name": "bbb",
                  "subs": [
                    {
                      "name": "ccc",
                      "subs": [
                        {
                          "name": "ddd",
                          "payload": "xyz"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "xyz"
      }
    ],
    "identifier": 43946092
  },
  {
    "context": [
      "How to convert it into the following by `jq`?",
      "The key here is the \"-c\" option, which in effect tells jq to use the JSONLines output format.",
      "In your particular case, the solution is simply:",
      "    jq -c '.[]'"
    ],
    "utterance": "Output each top-level object value as a single line in compact form, suitable for BigQuery.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "data": [
      {
        "input": {
          "1": {
            "kind": "person",
            "fullName": "John Doe",
            "age": 22,
            "gender": "Male",
            "citiesLived": [
              {
                "place": "Seattle",
                "numberOfYears": 5
              },
              {
                "place": "Stockholm",
                "numberOfYears": 6
              }
            ]
          },
          "2": {
            "kind": "person",
            "fullName": "Jane Austen",
            "age": 24,
            "gender": "Female",
            "citiesLived": [
              {
                "place": "Los Angeles",
                "numberOfYears": 2
              },
              {
                "place": "Tokyo",
                "numberOfYears": 2
              }
            ]
          }
        },
        "output": [
          {
            "kind": "person",
            "fullName": "John Doe",
            "age": 22,
            "gender": "Male",
            "citiesLived": [
              {
                "place": "Seattle",
                "numberOfYears": 5
              },
              {
                "place": "Stockholm",
                "numberOfYears": 6
              }
            ]
          },
          {
            "kind": "person",
            "fullName": "Jane Austen",
            "age": 24,
            "gender": "Female",
            "citiesLived": [
              {
                "place": "Los Angeles",
                "numberOfYears": 2
              },
              {
                "place": "Tokyo",
                "numberOfYears": 2
              }
            ]
          }
        ]
      }
    ],
    "identifier": 43910858
  },
  {
    "context": [
      "I built following filter on jqplay:",
      ". | {cruise_nid: .nid} + {nights: .nights} + {zone: .zones[].title} +  {sails_nid: .sails[].nid} + {arrival: .sails[].arrival} + {departure: .sails[].departure} + {cabintype: .sails[].cabins[].cabinType.kindName} + {catalogprice: .sails[].cabins[].catalogPrice} + {discountprice: .sails[].cabins[].discountPrice} + {currency: .sails[].cabins[].currency}",
      "The result is like:",
      "{\n  \"cruise_nid\": 434508,\n  \"nights\": 121,\n  \"zone\": \"Weltreise\",\n  \"sails_nid\": 434516,\n  \"arrival\": 1525644000,\n  \"departure\": 1515193200,\n  \"cabintype\": \"Innenkabine\",\n  \"catalogprice\": 17879,\n  \"discountprice\": 9519,\n  \"currency\": \"EUR\"\n}",
      "But i receive 194481 objects (arround 50 mb file). I actually have no idea why that happens and how i can fix it.",
      "If you want \"all combinations\" of zones, sails, and cabins, simply replace [0] with [] in the above:",
      "{nid, nights, zone: .zones[].title} +\n(.sails[]\n | ({ sails_nid: .nid, arrival, departure } ) +\n    (.cabins[] \n     | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, currency } ) )",
      "With the sample input, this emits 21 JSON objects."
    ],
    "utterance": "Extract a flat object for each combination of zone, sail, and cabin with fields: cruise_nid, nights, zone, sails_nid, arrival, departure, cabintype, catalogprice, discountprice, currency.",
    "expressions": [
      "{nid, nights, zone: .zones[].title} + (.sails[] | ({ sails_nid: .nid, arrival, departure } ) + (.cabins[] | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, currency } ))"
    ],
    "data": [
      {
        "input": {
          "nid": 434508,
          "nights": 121,
          "zones": [
            {
              "nid": 35761,
              "title": "Weltreise"
            }
          ],
          "sails": [
            {
              "nid": 434516,
              "arrival": 1525644000,
              "departure": 1515193200,
              "cabins": [
                {
                  "cabinType": {
                    "kindName": "Innenkabine"
                  },
                  "catalogPrice": 17879,
                  "discountPrice": 9519,
                  "currency": "EUR"
                }
              ]
            }
          ]
        },
        "output": {
          "nid": 434508,
          "nights": 121,
          "zone": "Weltreise",
          "sails_nid": 434516,
          "arrival": 1525644000,
          "departure": 1515193200,
          "cabintype": "Innenkabine",
          "catalogPrice": 17879,
          "discountPrice": 9519,
          "currency": "EUR"
        }
      }
    ],
    "identifier": 43755787
  },
  {
    "context": [
      "I want to add a parent to each of the json objects within a file.",
      "Then I need to put each json item into a parent\n\n       \"PutRequest\": {\n                \"Item\": {\n                ...\n                }\n       }\nand generate an array out of the json items.",
      "But I don't know how to add a parent to each json item.",
      "jq -s '{staticstring:[{PutRequest:{Item:.[]}}]}' **inputfile.json**"
    ],
    "utterance": "Wrap each object in the file as { PutRequest: { Item: ... } }, collect them into an array, and place that array under the key 'staticstring'.",
    "expressions": [
      "jq -s '{staticstring:[{PutRequest:{Item:.[]}}]}' inputfile.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": {
              "S": "cf7ebec368f241ead7ecf818ce9ed098406afa63"
            },
            "test": {
              "N": "5"
            },
            "added": {
              "S": "2017-02-15T17:56:19.958917+00:00"
            },
            "foo": {
              "N": "88"
            },
            "web": {
              "N": "103"
            }
          },
          {
            "id": {
              "S": "cf7ebec368f241ead7ecf818ce9ed098406afa63"
            },
            "image_server_id": {
              "N": "5"
            },
            "added": {
              "S": "2017-02-15T17:56:19.958917+00:00"
            },
            "result": {
              "N": "88"
            },
            "data": {
              "foo": {
                "N": "103",
                "S": "test"
              }
            }
          }
        ],
        "output": {
          "staticstring": [
            {
              "PutRequest": {
                "Item": {
                  "id": {
                    "S": "cf7ebec368f241ead7ecf818ce9ed098406afa63"
                  },
                  "test": {
                    "N": "5"
                  },
                  "added": {
                    "S": "2017-02-15T17:56:19.958917+00:00"
                  },
                  "foo": {
                    "N": "88"
                  },
                  "web": {
                    "N": "103"
                  }
                }
              }
            },
            {
              "PutRequest": {
                "Item": {
                  "id": {
                    "S": "cf7ebec368f241ead7ecf818ce9ed098406afa63"
                  },
                  "image_server_id": {
                    "N": "5"
                  },
                  "added": {
                    "S": "2017-02-15T17:56:19.958917+00:00"
                  },
                  "result": {
                    "N": "88"
                  },
                  "data": {
                    "foo": {
                      "N": "103",
                      "S": "test"
                    }
                  }
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 43950580
  },
  {
    "context": [
      "How do I convert these two text strings into separate json objects",
      "start process: Mon May 15 03:14:09 UTC 2017",
      "logfilename: log_download_2017",
      "Json output:",
      "{\n\"start process\": \"Mon May 15 03:14:09 UTC 2017\",\n}",
      "{\n\"logfilename\": \"log_download_2017\",\n}",
      "jq -R 'index(\":\") as $ix | {(.[:$ix]) : .[$ix+1:]}'",
      "jq -R 'match( \"([^:]*):(.*)\" ) | .captures | {(.[0].string): .[1].string}'",
      "jq -R '[capture( \"(?<key>[^:]*):(?<value>.*)\" )] | from_entries'"
    ],
    "utterance": "Convert each text line of the form 'key: value' into a separate object mapping the key to the value.",
    "expressions": [
      "jq -R 'index(\":\") as $ix | {(.[:$ix]) : .[$ix+1:]}'",
      "jq -R 'match( \"([^:]*):(.*)\" ) | .captures | {(.[0].string): .[1].string}'",
      "jq -R '[capture( \"(?<key>[^:]*):(?<value>.*)\" )] | from_entries'"
    ],
    "data": [
      {
        "input": "start process: Mon May 15 03:14:09 UTC 2017",
        "output": {
          "start process": "Mon May 15 03:14:09 UTC 2017"
        }
      },
      {
        "input": "logfilename: log_download_2017",
        "output": {
          "logfilename": "log_download_2017"
        }
      }
    ],
    "identifier": 43972268
  },
  {
    "context": [
      "I am passing username and password to jq the following way:",
      "json=$(jq -n --arg u \"user_dev\" --arg p \"user!\" '{username: $u, password: $p}')",
      "-bash: !\": event not found",
      "It seem that it is not liking exclamation mark with the `arg p \"user!\"`",
      "Use single quotes instead to prevent that.",
      "json=$(jq -n --arg u \"user_dev\" --arg p 'user!' '{username: $u, password: $p}')"
    ],
    "utterance": "Create an object with username user_dev and password user! as string values, ensuring the exclamation mark is handled correctly.",
    "expressions": [
      "jq -n --arg u \"user_dev\" --arg p 'user!' '{username: $u, password: $p}'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "username": "user_dev",
          "password": "user!"
        }
      }
    ],
    "identifier": 43987641
  },
  {
    "context": [
      "I want to set a parameter to define which value from \"bla\" should be changed. I want to start the script for example like this:\n\n> $ ./myscript.sh test1",
      "jq --arg v $1 '.pokemon.$v = \"True\"' filters.json > tmp.$$.json && mv tmp.$$.json filters.json",
      "error: syntax error, unexpected '$', expecting IDENT\n.pokemon.$v = \"True\"",
      "You need to use the `[...]` subscripting syntax instead of the `.` syntax if you want to use a variable in the subscript:\n\n    .pokemon[$v] = \"True\""
    ],
    "utterance": "Set the value of a given key inside the 'bla' object to 'True', where the key name is provided as a shell script argument.",
    "expressions": [
      ".bla[$v] = \"True\""
    ],
    "data": [
      {
        "input": {
          "bla": {
            "test1": "True",
            "test2": "False"
          }
        },
        "output": {
          "bla": {
            "test1": "True",
            "test2": "False"
          }
        }
      }
    ],
    "identifier": 44010890
  },
  {
    "context": [
      "but in that case the JSON script can only see one line at a time, so it doesn't work correctly.",
      "{\n  echo \"start filelist:\"\n  printf '%s\\n' \"$PWD\"/*\n\n  echo \"start wget:\"\n  wget -nv http://web.site.com/downloads/2017/file_1.zip 2>&1\n  wget -nv http://web.site.com/downloads/2017/file_2.zip 2>&1\n} | tee -a \"$logfilename\" | jq -sRf json_log_s2o.jq >>\"${logfilename}.json\""
    ],
    "utterance": "Combine the output of multiple shell commands and process the aggregated result using a script file in a single invocation.",
    "expressions": [
      "{ echo \"start filelist:\"; printf '%s\\n' \"$PWD\"/*; echo \"start wget:\"; wget -nv http://web.site.com/downloads/2017/file_1.zip 2>&1; wget -nv http://web.site.com/downloads/2017/file_2.zip 2>&1; } | tee -a \"$logfilename\" | jq -sRf json_log_s2o.jq >>\"${logfilename}.json\""
    ],
    "identifier": 44021118
  },
  {
    "context": [
      "How do I convert these two text strings into a single json object",
      "Text strings:",
      "    start process: Mon May 15 03:14:09 UTC 2017",
      "    logfilename: log_download_2017",
      "Json output:",
      "    {",
      "    \"start process\": \"Mon May 15 03:14:09 UTC 2017\",",
      "    \"logfilename\": \"log_download_2017\",",
      "    }",
      "To combine the objects, you could use `add`.  To do this in a single pass, you would use jq -R -s",
      "Putting it all together, you could do worse than:",
      "def trim: sub(\"^ +\";\"\") | sub(\" +$\";\"\");",
      "def s2o:",
      "  (index(\":\") // empty) as $ix",
      "  | {(.[:$ix]): (.[$ix+1:]|trim)};",
      "split(\"\\n\") | map(s2o) | add"
    ],
    "utterance": "Convert two lines formatted as 'key: value' into a single object where the keys and values are extracted from each line.",
    "expressions": [
      "def trim: sub(\"^ +\";\"\") | sub(\" +$\";\"\");\ndef s2o: (index(\":\") // empty) as $ix | {(.[:$ix]): (.[$ix+1:]|trim)};\nsplit(\"\\n\") | map(s2o) | add"
    ],
    "data": [
      {
        "input": "start process: Mon May 15 03:14:09 UTC 2017\nlogfilename: log_download_2017",
        "output": {
          "start process": "Mon May 15 03:14:09 UTC 2017",
          "logfilename": "log_download_2017"
        }
      }
    ],
    "identifier": 44014822
  },
  {
    "context": [
      "I&#39;m trying to extract the fields:",
      ".ReservedInstancesOfferings[].ProductDescription",
      ".ReservedInstancesOfferings[].InstanceType",
      ".ReservedInstancesOfferings[].RecurringCharges[].Amount",
      "I would like to output to appear like this:",
      "\"Red Hat Enterprise Linux\"",
      "\"c4.xlarge\"",
      "0.183",
      "OK, so I managed to get what I was after...",
      "jq '.ReservedInstancesOfferings[] | [.ProductDescription, .InstanceType, .RecurringCharges[].Amount]'",
      "Output:",
      "[",
      "  \"Linux/UNIX\",",
      "  \"c4.xlarge\",",
      "  0.167",
      "]"
    ],
    "utterance": "List each offering's ProductDescription, InstanceType, and each RecurringCharges Amount together as array entries.",
    "expressions": [
      ".ReservedInstancesOfferings[] | [.ProductDescription, .InstanceType, .RecurringCharges[].Amount]"
    ],
    "data": [
      {
        "input": {
          "ReservedInstancesOfferings": [
            {
              "OfferingClass": "convertible",
              "OfferingType": "No Upfront",
              "AvailabilityZone": "ap-southeast-2a",
              "InstanceTenancy": "default",
              "PricingDetails": [],
              "ProductDescription": "Linux/UNIX",
              "UsagePrice": 0.0,
              "RecurringCharges": [
                {
                  "Amount": 0.167,
                  "Frequency": "Hourly"
                }
              ],
              "Marketplace": false,
              "CurrencyCode": "USD",
              "FixedPrice": 0.0,
              "Duration": 94608000,
              "Scope": "Availability Zone",
              "ReservedInstancesOfferingId": "1fc8c02b-bcc0-42b8-82ef-47c6f6d1c1b5",
              "InstanceType": "c4.xlarge"
            },
            {
              "OfferingClass": "convertible",
              "OfferingType": "No Upfront",
              "AvailabilityZone": "ap-southeast-2a",
              "InstanceTenancy": "dedicated",
              "PricingDetails": [],
              "ProductDescription": "Red Hat Enterprise Linux",
              "UsagePrice": 0.0,
              "RecurringCharges": [
                {
                  "Amount": 0.243,
                  "Frequency": "Hourly"
                }
              ],
              "Marketplace": false,
              "CurrencyCode": "USD",
              "FixedPrice": 0.0,
              "Duration": 94608000,
              "Scope": "Availability Zone",
              "ReservedInstancesOfferingId": "24aaceee-f54e-4882-aba3-ce710a5036c9",
              "InstanceType": "c4.xlarge"
            }
          ]
        },
        "output": [
          [
            "Linux/UNIX",
            "c4.xlarge",
            0.167
          ],
          [
            "Red Hat Enterprise Linux",
            "c4.xlarge",
            0.243
          ]
        ]
      }
    ],
    "identifier": 43994979
  },
  {
    "context": [
      "I am trying to get `jq` to return both the keyname as well as the isAvailable value.",
      "Here is the json being returned by the API call.",
      "A simple `jq` filter like below would be sufficient,\r\n\r\n    command-producing-json | jq '[ .keyname, .location.locationPackageDetails[].isAvailable ]'",
      "would produce below as expected.\r\n\r\n    [\r\n      \"AMSTERDAM03\",\r\n      1\r\n    ]"
    ],
    "utterance": "Return an array containing the keyname and the isAvailable value for each region entry.",
    "expressions": [
      ".[] | [ .keyname, .location.locationPackageDetails[].isAvailable ]"
    ],
    "data": [
      {
        "input": [
          {
            "description": "AMS03 - Amsterdam",
            "keyname": "AMSTERDAM03",
            "location": {
              "location": {
                "id": 814994,
                "longName": "Amsterdam 3",
                "name": "ams03",
                "statusId": 2
              },
              "locationPackageDetails": [
                {
                  "isAvailable": 1,
                  "locationId": 814994,
                  "packageId": 737
                }
              ]
            },
            "sortOrder": 2
          }
        ],
        "output": [
          "AMSTERDAM03",
          1
        ]
      }
    ],
    "identifier": 44030810
  },
  {
    "context": [
      "How do I convert these lists of text strings into json",
      "Text strings:\r\n\r\n    start filelist:\r\n    /download/2017/download_2017.sh\r\n    /download/2017/log_download_2017.json\r\n    /download/2017/log_download_2017.txt\r\n    start wget:\r\n    2017-05-15 20:42:00 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -&gt; \"file_1.zip\" [1]\r\n    2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -&gt; \"file_2.zip\" [1]",
      "JSON output:\r\n\r\n    {\r\n    \"start filelist\": [\r\n        \"download_2017.sh\",\r\n        \"log_download_2017.txt\",\r\n        \"log_download_2017.json\",\r\n      ],\r\n    }\r\n    {\r\n    \"start wget\": [\r\n        \"2017-05-15 20:43:01 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -> \"file_1.zip\" [1]\",\r\n        \"2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -> \"file_2.zip\" [1]\",\r\n      ],\r\n    }",
      "Here's a jq-only solution, which produces valid JSON along the lines of your example:",
      "foreach (inputs,null) as $line ({};\n   if $line == null then .emit = {(.key): .value}\n   elif $line[-1:] == \":\"\n   then (if .key then {emit: {(.key): .value}} else null end)\n        + { key : $line[0:-1] }\n   else {key, value: (.value + [$line])}\n   end;\n   .emit // empty )",
      "jq -n -R -f program.jq input.txt"
    ],
    "utterance": "Convert a text file containing sections marked by header lines ending with ':' and their subsequent lines into a stream of JSON objects, each mapping the header to a list of strings belonging to that section.",
    "expressions": [
      "foreach (inputs,null) as $line ({};\n   if $line == null then .emit = {(.key): .value}\n   elif $line[-1:] == \":\"\n   then (if .key then {emit: {(.key): .value}} else null end)\n        + { key : $line[0:-1] }\n   else {key, value: (.value + [$line])}\n   end;\n   .emit // empty )"
    ],
    "data": [
      {
        "input": "start filelist:\n/download/2017/download_2017.sh\n/download/2017/log_download_2017.json\n/download/2017/log_download_2017.txt\nstart wget:\n2017-05-15 20:42:00 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -> \"file_1.zip\" [1]\n2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -> \"file_2.zip\" [1]",
        "output": [
          {
            "start filelist": [
              "/download/2017/download_2017.sh",
              "/download/2017/log_download_2017.json",
              "/download/2017/log_download_2017.txt"
            ]
          },
          {
            "start wget": [
              "2017-05-15 20:42:00 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -> \"file_1.zip\" [1]",
              "2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -> \"file_2.zip\" [1]"
            ]
          }
        ]
      }
    ],
    "identifier": 43989072
  },
  {
    "context": [
      "I would like the filter to be more flexible so that it can show the data structure from `containers` down to any package manager with a title that starts with `Packages`. I need the whole structure, though, and not just the terminal nodes.",
      "I *think* I need is to express my object identifiers with alternation or wildcards, such as:",
      "- `.capabilities.*.payload?`",
      "- `.capabilities.([apk, dpkg, rpm]).payload?`",
      "The trick is to define a helper function.  If, for example, you write:\r\n\r\n    def payloads(keys): . as $in\r\n      | reduce keys[] as $key ({}; .[$key] = ($in|.[$key].payload?) );",
      "then your query becomes:\r\n\r\n    .containers[] | { \r\n        name: .container_name,\r\n \t    package_inventory: (.capabilities | payloads( [\"apk\",\"dpkg\",\"rpm\"] ))\r\n    }",
      "This helper function is perhaps closer to what you're looking for:\r\n\r\n    def star(pre; template; post):\r\n      pre as $object\r\n      | ({} | [($object|template|keys_unsorted[]) as $key | .[$key] = ($object | .[$key] | post) ])\r\n      | add;",
      "Explicit list of key names:\r\n\r\n    star(.capabilities; {apk,dpkg,rpm}; .payload)",
      "Keys of .capabilities:\r\n\r\n\tstar(.capabilities; .; .payload)",
      "Example:\r\n\r\n    .containers[] | { \r\n        name: .container_name,\r\n\t    package_inventory: star(.capabilities; .; .payload)\r\n    }"
    ],
    "utterance": "List each container's name and a package_inventory object containing the payloads (if present) for the package managers apk, dpkg, and rpm.",
    "expressions": [
      "def payloads(keys): . as $in | reduce keys[] as $key ({}; .[$key] = ($in|.[$key].payload?) );\n[ .containers[] | { name: .container_name, package_inventory: (.capabilities | payloads([\"apk\",\"dpkg\",\"rpm\"])) } ]",
      "def star(pre; template; post): pre as $object | ({} | [($object|template|keys_unsorted[]) as $key | .[$key] = ($object | .[$key] | post) ]) | add;\n[ .containers[] | { name: .container_name, package_inventory: star(.capabilities; {apk,dpkg,rpm}; .payload) } ]"
    ],
    "data": [
      {
        "input": {
          "containers": {
            "3dc76c82e566a116e5b64bc91a0b6220c71db7052f68317ebbe90521db55bf36": {
              "container_name": "/apache-46869",
              "capabilities": {
                "apk": {
                  "title": "Packages (APK)"
                },
                "dpkg": {
                  "title": "Packages (DPKG)",
                  "payload": {
                    "apt": "1.0.9.8.4",
                    "libnghttp2-14": "1.18.1-1"
                  }
                },
                "rpm": {
                  "title": "Packages (RPM)"
                }
              }
            },
            "474047a1fe238e39fa1917aff0c93154624bbf159d321d49d5e685302589ab51": {
              "container_name": "/nginx-alpine-46869",
              "capabilities": {
                "apk": {
                  "title": "Packages (APK)",
                  "payload": {
                    ".nginx-rundeps": "0",
                    "apk-tools": "2.6.8-r2"
                  }
                },
                "dpkg": {
                  "title": "Packages (DPKG)"
                },
                "rpm": {
                  "title": "Packages (RPM)"
                }
              }
            },
            "d7dcd90791240d78022941cf054a6b474f5329acd79aa15b58dc342f95a8ce33": {
              "container_name": "/apache-alpine-46869",
              "capabilities": {
                "apk": {
                  "title": "Packages (APK)",
                  "payload": {
                    ".httpd-rundeps": "0",
                    "apk-tools": "2.6.8-r2",
                    "apr": "1.5.2-r1",
                    "apr-util": "1.5.4-r2"
                  }
                },
                "dpkg": {
                  "title": "Packages (DPKG)"
                },
                "rpm": {
                  "title": "Packages (RPM)"
                }
              }
            }
          }
        },
        "output": [
          {
            "name": "/apache-46869",
            "package_inventory": {
              "apk": null,
              "dpkg": {
                "apt": "1.0.9.8.4",
                "libnghttp2-14": "1.18.1-1"
              },
              "rpm": null
            }
          },
          {
            "name": "/nginx-alpine-46869",
            "package_inventory": {
              "apk": {
                ".nginx-rundeps": "0",
                "apk-tools": "2.6.8-r2"
              },
              "dpkg": null,
              "rpm": null
            }
          },
          {
            "name": "/apache-alpine-46869",
            "package_inventory": {
              "apk": {
                ".httpd-rundeps": "0",
                "apk-tools": "2.6.8-r2",
                "apr": "1.5.2-r1",
                "apr-util": "1.5.4-r2"
              },
              "dpkg": null,
              "rpm": null
            }
          }
        ]
      }
    ],
    "identifier": 43822906
  },
  {
    "context": [
      "I would like to iterate over the string of the field \"field2.1; Field2.2 Field2.3\", three \";\" separated items at a time to produce an array of key value pairs",
      "if the following JSON is in input.json:\n\n    {\n     \"field1\" : \"value1\",\n     \"field2.1; Field2.2; Field2.3\" : \"Field2.1Value0; Field2.2Value0; Field2.3Value0\"\n    }\n\nthen the invocation:\n\n    jq -f program.jq input.json\n\nshould yield:\n\n    [\n      {\n        \"field1\": \"value1\"\n      },\n      {\n        \"field2.1\": \"Field2.1Value0\",\n        \"Field2.2\": \"Field2.2Value0\",\n        \"Field2.3\": \"Field2.3Value0\"\n      }\n    ]",
      "Now let's modify the above so that headers will be recycled in accordance with the problem statement.\n\ndef objectifyRows(headers):\n  (headers|length) as $m\n  | (length / $m)  as $n\n  | . as $in\n  | reduce range(0; $n) as $i ( [];\n      .[$i] = (reduce range(0; $m) as $h ({};\n                 .[headers[$h]] = $in[($i * $m) + $h] ) ) );\n\ndef devolveRows:\n  if .key|index(\";\")\n  then .key as $key\n  | ( [.value | splits(\"; *\")] ) \n  | objectifyRows([$key | splits(\"; *\")])\n  else { (.key): .value }\n  end;\n\nto_entries | map( devolveRows )",
      "Here is my almost final solution that inserts the new key as well as uses the first element of the \";\" list as the key for sorting the array.\n\ndef objectifyRows(headers):\n  (headers|length) as $m\n  | (headers[0]) as $firstkey\n  | (length / $m)  as $n\n  | . as $in\n  | reduce range(0; $n) as $i ( [];\n      .[$i] = (reduce range(0; $m) as $h ({};\n                 .[headers[$h]] = $in[($i * $m) + $h] ) ) )\n  ;\n\ndef devolveRows:\n  if .key|index(\";\")\n  then .key as $multikey\n    | ( [.value | splits(\"; *\")] ) \n    # Create a new key with value being an array of the \"splits\" \n    | { ($multikey): objectifyRows([$multikey | splits(\"; *\")])}\n    # here \"arbitrarily\" sort by the first split key\n    | .[$multikey] |= sort_by(.[[$multikey | splits(\"; *\")][0]])\n  else { (.key): .value }\n  end;\n\nto_entries | map( devolveRows )"
    ],
    "utterance": "For each object, transform keys containing semicolon-separated subfield names so that their semicolon-separated values are expanded into an array of objects that map subfield names to groups of values, grouped according to the number of subfields.",
    "expressions": [
      "def objectifyRows(headers):\n  (headers|length) as $m\n  | (length / $m)  as $n\n  | . as $in\n  | reduce range(0; $n) as $i ( [];\n      .[$i] = (reduce range(0; $m) as $h ({};\n                 .[headers[$h]] = $in[($i * $m) + $h] ) ) );\n\ndef devolveRows:\n  if .key|index(\";\")\n  then .key as $key\n  | ( [.value | splits(\"; *\")] ) \n  | objectifyRows([$key | splits(\"; *\")])\n  else { (.key): .value }\n  end;\n\nto_entries | map( devolveRows )",
      "def objectifyRows(headers):\n  (headers|length) as $m\n  | (headers[0]) as $firstkey\n  | (length / $m)  as $n\n  | . as $in\n  | reduce range(0; $n) as $i ( [];\n      .[$i] = (reduce range(0; $m) as $h ({};\n                 .[headers[$h]] = $in[($i * $m) + $h] ) ) )\n  ;\n\ndef devolveRows:\n  if .key|index(\";\")\n  then .key as $multikey\n    | ( [.value | splits(\"; *\")] ) \n    | { ($multikey): objectifyRows([$multikey | splits(\"; *\")])}\n    | .[$multikey] |= sort_by(.[[$multikey | splits(\"; *\")][0]])\n  else { (.key): .value }\n  end;\n\nto_entries | map( devolveRows )"
    ],
    "data": [
      {
        "input": {
          "field1": "value1",
          "field2.1; Field2.2; Field2.3": "Field2.1Value0; Field2.2Value0; Field2.3Value0"
        },
        "output": [
          {
            "field1": "value1"
          },
          {
            "field2.1": "Field2.1Value0",
            "Field2.2": "Field2.2Value0",
            "Field2.3": "Field2.3Value0"
          }
        ]
      },
      {
        "input": {
          "field1": "value1",
          "field2.1; Field2.2; Field2.3": "Field2.1Value0; Field2.2Value0; Field2.3Value0; Field2.4Value0; Field2.5Value0; Field2.6Value0"
        },
        "output": [
          {
            "field1": "value1"
          },
          [
            {
              "field2.1": "Field2.1Value0",
              "Field2.2": "Field2.2Value0",
              "Field2.3": "Field2.3Value0"
            },
            {
              "field2.1": "Field2.4Value0",
              "Field2.2": "Field2.5Value0",
              "Field2.3": "Field2.6Value0"
            }
          ]
        ]
      }
    ],
    "identifier": 43771630
  },
  {
    "context": [
      "I\u2019d like to selectively extract some of the fields and get a csv output like this:\n\n    field1,field2,field3,id\n    a,aa,aaa,1\n    b,bb,bbb,2\n    c,cc,ccc,3\n    d,dd,ddd,4",
      "jq -r '(([[\"field1\", \"field2\", \"field3\", \"id\"]]) + [(.main.All[] | [.field1,.field2,.field3,.id])])[]|@csv' data.json",
      "jq -r --argjson f '[\"field1\", \"field2\", \"field3\", \"id\"]' '\n  $f, (.table.All[] | [getpath( $f[]|[.])]) | @csv'"
    ],
    "utterance": "Extract the values of 'field1', 'field2', 'field3', and 'id' from each entry in the 'main.All' array and output them as a CSV with a header row.",
    "expressions": [
      "jq -r '(([[\"field1\", \"field2\", \"field3\", \"id\"]]) + [(.main.All[] | [.field1,.field2,.field3,.id])])[]|@csv' data.json",
      "jq -r --argjson f '[\"field1\", \"field2\", \"field3\", \"id\"]' '$f, (.main.All[] | [getpath( $f[]|[.])]) | @csv'"
    ],
    "data": [
      {
        "input": {
          "res": "0",
          "main": {
            "All": [
              {
                "field1": "a",
                "field2": "aa",
                "field3": "aaa",
                "field4": "0",
                "active": "true",
                "id": "1"
              },
              {
                "field1": "b",
                "field2": "bb",
                "field3": "bbb",
                "field4": "0",
                "active": "false",
                "id": "2"
              },
              {
                "field1": "c",
                "field2": "cc",
                "field3": "ccc",
                "field4": "0",
                "active": "true",
                "id": "3"
              },
              {
                "field1": "d",
                "field2": "dd",
                "field3": "ddd",
                "field4": "0",
                "active": "true",
                "id": "4"
              }
            ]
          }
        },
        "output": [
          "\"field1\",\"field2\",\"field3\",\"id\"",
          "\"a\",\"aa\",\"aaa\",\"1\"",
          "\"b\",\"bb\",\"bbb\",\"2\"",
          "\"c\",\"cc\",\"ccc\",\"3\"",
          "\"d\",\"dd\",\"ddd\",\"4\""
        ]
      }
    ],
    "identifier": 44029906
  }
]