[
  {
    "context": [
      "My goal is to extract the `preview_url` -- thus, for the input above, to get the output `https://archive.org/details/isbn_9780393972818`.",
      "jq: error: syntax error, unexpected ':'",
      "What you want is:\n\n    jq -r '[\"ISBN:039397281X\"].preview_url'\n\nor, more simply:\n\n    jq -r '[].preview_url'"
    ],
    "utterance": "Extract the 'preview_url' value from the object with key 'ISBN:039397281X'.",
    "expressions": [
      ".[\"ISBN:039397281X\"].preview_url",
      ".[].preview_url"
    ],
    "data": [
      {
        "input": {
          "ISBN:039397281X": {
            "bib_key": "ISBN:039397281X",
            "preview": "borrow",
            "thumbnail_url": "https://covers.openlibrary.org/b/id/7890978-S.jpg",
            "preview_url": "https://archive.org/details/isbn_9780393972818",
            "info_url": "https://openlibrary.org/books/OL348852M/Don_Quijote"
          }
        },
        "output": "https://archive.org/details/isbn_9780393972818"
      }
    ],
    "identifier": 45223809
  },
  {
    "identifier": 45306246
  },
  {
    "context": [
      "SELECT needs to be a variable and not hardcoded in the script.",
      "jq --arg select_str \"$select\" '\n($select_str\n | split(\",\")\n | reduce .[] as $item ({}; .[$item]=$item)) as $select_map\n | with_entries(select($select_map[.key]))' <<<\"$j\"",
      "jq -c --arg P1 \"$SELECT\" '\n  . as $in | $P1 | split(\",\") | map( {(.): $in[.]} ) | add\n'",
      "Output:\n\n    {\"a\":1,\"b\":10}"
    ],
    "utterance": "Extract only the keys listed in the variable SELECT, whose value is a comma-separated string like 'a,b', from each object.",
    "expressions": [
      "($select_str | split(\",\") | reduce .[] as $item ({}; .[$item]=$item)) as $select_map | with_entries(select($select_map[.key]))",
      ". as $in | $P1 | split(\",\") | map( {(.): $in[.]} ) | add"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 10,
          "c": 100
        },
        "output": {
          "a": 1,
          "b": 10
        }
      }
    ],
    "identifier": 45289450
  },
  {
    "context": [
      "I have the following `jq` command:\r\n\r\n    cat myFile.json | jq -r '.tickets[] | [.created_at, .id, .via.channel, .tags[]] | @csv'\r\n\r\nAnd it outputs a line such as:\r\n\r\n    \"2016-02-02T10:00:00Z\",99999,\"web\",\"tag1\",\"tag2\",\"tag3\",\"tag4\"",
      "I'm trying to `join` the `.tags[]` array, so that I can get:\r\n\r\n    \"2016-02-19T13:25:55Z\",99999,\"web\",\"tag1,tag2,tag3,tag4\"",
      "You need to call `join()` on the `tags` list, not the individual tags. Try with:\r\n\r\n    jq -r '.tickets[] | [.created_at, .id, .via.channel, (.tags | join(\",\"))] | @csv'"
    ],
    "utterance": "Produce table rows where the tags field is a single comma-separated string combining all tag values.",
    "expressions": [
      ".tickets[] | [.created_at, .id, .via.channel, (.tags | join(\",\"))] | @csv"
    ],
    "data": [
      {
        "input": {
          "tickets": [
            {
              "created_at": "2016-02-02T10:00:00Z",
              "id": 99999,
              "via": {
                "channel": "web"
              },
              "tags": [
                "tag1",
                "tag2",
                "tag3",
                "tag4"
              ]
            }
          ]
        },
        "output": "\"2016-02-02T10:00:00Z\",99999,\"web\",\"tag1,tag2,tag3,tag4\""
      }
    ],
    "identifier": 45165303
  },
  {
    "context": [
      "I have to grab ID and Name in the same line so I can do some logic after.",
      "I want to get:\r\n\r\n    15f959fc-6d2d-451a-a59e-430a05a1852c Mike\r\n    d892f2eb-d7f3-49f8-9176-2113351cccf8 Steve",
      "Apply string concatenation:\r\n\r\n    jq '.elements[] | .id +\" \"+ .name' file",
      "To output without double quotes use `-r` (`--raw-output`) option:\r\n\r\n    jq '.elements[] | .id +\" \"+ .name' -r file"
    ],
    "utterance": "List each element's id and name concatenated with a space, one per line.",
    "expressions": [
      ".elements[] | .id + \" \" + .name"
    ],
    "data": [
      {
        "input": {
          "elements": [
            {
              "id": "e20a9cd8-8683-4986-b6c0-e5fbf51cbf7f",
              "name": "Mike",
              "components": [
                {
                  "id": "15f959fc-6d2d-451a-a59e-430a05a1852c",
                  "pid": "ZZZ1"
                }
              ],
              "tenantIds": null,
              "productIds": null
            },
            {
              "id": "d892f2eb-d7f3-49f8-9176-2113351cccf8",
              "name": "Steve",
              "components": [
                {
                  "id": "0c44c917-e0e5-4fa3-b87c-89f9ac0815b4",
                  "pid": "XXX3"
                }
              ],
              "tenantIds": null,
              "productIds": null
            }
          ]
        },
        "output": [
          "e20a9cd8-8683-4986-b6c0-e5fbf51cbf7f Mike",
          "d892f2eb-d7f3-49f8-9176-2113351cccf8 Steve"
        ]
      }
    ],
    "identifier": 45232603
  },
  {
    "context": [
      "I want to get the items where the `reviewer` is the same as `author` after excluding the reviewer `build`.",
      "i.e. I want to get items with `id`s 2, 3.",
      "but item with `id` 1 is false positive and I want to filter that out too.",
      "I believe this is what you&#39;re looking for:\r\n\r\n    .[]\r\n    | select( .author as $author\r\n              | .reviewers\r\n              | map(select(.name != \"build\"))        # ignore \"build\"\r\n              | length==1 and .[0].name == $author )"
    ],
    "utterance": "Return objects where the list of reviewers, after excluding reviewers named 'build', contains exactly one reviewer whose name matches the author.",
    "expressions": [
      ".[] | select( .author as $author | .reviewers | map(select(.name != \"build\")) | length==1 and .[0].name == $author )"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "author": "hippy",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              },
              {
                "name": "other",
                "status": "ok"
              }
            ]
          },
          {
            "id": 2,
            "author": "hippy",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              },
              {
                "name": "build",
                "status": "ok"
              }
            ]
          },
          {
            "id": 3,
            "author": "hippy",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              }
            ]
          },
          {
            "id": 4,
            "author": "other",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              }
            ]
          }
        ],
        "output": [
          {
            "id": 2,
            "author": "hippy",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              },
              {
                "name": "build",
                "status": "ok"
              }
            ]
          },
          {
            "id": 3,
            "author": "hippy",
            "reviewers": [
              {
                "name": "hippy",
                "status": "ok"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 45263679
  },
  {
    "context": [
      "I have a stream of JSON arrays like this\n\n    [{\"id\":\"AQ\",\"Count\":0}]\n    [{\"id\":\"AR\",\"Count\":1},{\"id\":\"AR\",\"Count\":3},{\"id\":\"AR\",\"Count\":13},\n    {\"id\":\"AR\",\"Count\":12},{\"id\":\"AR\",\"Count\":5}]\n    [{\"id\":\"AS\",\"Count\":0}]\n\nI want to use jq to get a new json like this\n\n    {\"id\":\"AQ\",\"Count\":0}\n    {\"id\":\"AR\",\"Count\":34}\n    {\"id\":\"AS\",\"Count\":0}\n\n34=1+3+13+12+5 which are in the second array.",
      "jq -c '\n  reduce .[] as $item ({}; .[($item.id)] += ($item.Count))\n  | to_entries\n  | .[] | {\"id\": .key, \"Count\": .value}\n'",
      "Assuming the .id is the same in each array:\n\n    first + {Count: map(.Count) | add}",
      "(map(.Count) | add) as $sum | first | .Count = $sum",
      "{ id: (first|.id), Count: (map(.Count) | add) }",
      "reduce inputs as $row ({}; adder($row[]; .id; .Count) )"
    ],
    "utterance": "For each input array, output an object with the 'id' and the sum of all 'Count' values associated with that id.",
    "expressions": [
      "first + {Count: map(.Count) | add}",
      "(map(.Count) | add) as $sum | first | .Count = $sum",
      "{ id: (first|.id), Count: (map(.Count) | add) }"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "AQ",
              "Count": 0
            }
          ],
          [
            {
              "id": "AR",
              "Count": 1
            },
            {
              "id": "AR",
              "Count": 3
            },
            {
              "id": "AR",
              "Count": 13
            },
            {
              "id": "AR",
              "Count": 12
            },
            {
              "id": "AR",
              "Count": 5
            }
          ],
          [
            {
              "id": "AS",
              "Count": 0
            }
          ]
        ],
        "output": [
          {
            "id": "AQ",
            "Count": 0
          },
          {
            "id": "AR",
            "Count": 34
          },
          {
            "id": "AS",
            "Count": 0
          }
        ]
      }
    ],
    "identifier": 45194907
  },
  {
    "context": [
      "A jq program takes an input JSON document whose structure I&#39;m only vaguely familiar with, and I want it to print the path to all properties within it that have a certain name.",
      "Suppose you want to find the paths to objects with a key named \"b\".",
      "data | paths(objects | has(\"b\") )",
      "data | paths | select( .[-1] == \"b\" ) | .[:-1]"
    ],
    "utterance": "Print the path to every property with the name 'b', regardless of where it appears in the structure.",
    "expressions": [
      "paths(objects | has(\"b\"))",
      "paths | select( .[-1] == \"b\" ) | .[:-1]"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": 1,
            "c": {
              "b": 2
            }
          }
        },
        "output": [
          [
            "a"
          ],
          [
            "a",
            "c"
          ]
        ]
      }
    ],
    "identifier": 45345830
  },
  {
    "context": [
      "I want to count the number of items by each ItmId appeared in the json. For example, items that with \"ItmId\" 1694738780 appears 10 times and items with \"ItmId\" 1347809133 appears 14 times in my json file. Then return a json like this\n    {\"ItemId\": \"1694738780\",\n     \"Count\":  10\n    }\n    {\"ItemId\": \"1347809133\",\n     \"Count\":  14\n    }",
      "map({ItemId: .Properties.ItmId})             # extract the ItmID values\n| group_by(.ItemId)                          # group by \"ItemId\"\n| map({ItemId: .[0].ItemId, Count: length})  # store the counts\n| .[]                                        # convert to a stream",
      "def counter(stream):\n  reduce stream as $s ({}; .[$s|tostring] += 1);\n\ncounter(inputs | .Properties.ItmId)\n| to_entries[]\n| {ItemId: (.key), Count: .value}",
      "map(.Properties.ItmId)\n| reduce .[] as $i (\n    {}; setpath([$i]; getpath([$i]) + 1)\n  )\n| to_entries | .[] | { \"ItemId\": .key, \"Count\": .value }"
    ],
    "utterance": "Count how many times each distinct ItmId value appears and return an object for each with the ItmId and its count.",
    "expressions": [
      "map({ItemId: .Properties.ItmId}) | group_by(.ItemId) | map({ItemId: .[0].ItemId, Count: length}) | .[]",
      "def counter(stream): reduce stream as $s ({}; .[$s|tostring] += 1); counter(inputs | .Properties.ItmId) | to_entries[] | {ItemId: (.key), Count: .value}",
      "map(.Properties.ItmId)\n| reduce .[] as $i (\n    {}; setpath([$i]; getpath([$i]) + 1)\n  )\n| to_entries | .[] | { \"ItemId\": .key, \"Count\": .value }"
    ],
    "data": [
      {
        "input": [
          {
            "ReferringUrl": "N",
            "OpenAccess": "0",
            "Properties": {
              "ItmId": "1694738780"
            }
          },
          {
            "ReferringUrl": "L",
            "OpenAccess": "1",
            "Properties": {
              "ItmId": "1347809133"
            }
          },
          {
            "ReferringUrl": "L",
            "OpenAccess": "0",
            "Properties": {
              "ItmId": "1347809133"
            }
          }
        ],
        "output": [
          {
            "ItemId": "1694738780",
            "Count": 1
          },
          {
            "ItemId": "1347809133",
            "Count": 2
          }
        ]
      }
    ],
    "identifier": 45170897
  },
  {
    "context": [
      "I have two json files of the follwoing structure ",
      "I want to merge these files such that the output file looks like",
      "Thanks to the magic of jq's `-s` command-line option, you can \"add\" as many files as you like, like so:",
      "$ jq -s add file1.json file2.json"
    ],
    "utterance": "Combine two files, each containing an array, into a single array that concatenates their elements.",
    "expressions": [
      "jq -s add file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "line": 2,
              "elements": [
                {}
              ]
            }
          ],
          [
            {
              "line": 3,
              "elements": [
                {}
              ]
            }
          ]
        ],
        "output": [
          {
            "line": 2,
            "elements": [
              {}
            ]
          },
          {
            "line": 3,
            "elements": [
              {}
            ]
          }
        ]
      }
    ],
    "identifier": 45384683
  },
  {
    "context": [
      "i need to write a script in shell that will read this text file as a first argument and stores the value of \"example\" from that JSON in variable, using jq.",
      "cat \"$file\" | jq -j \".rows[].example\"",
      "variable=$(cat \"$file\" | jq -j \".rows[].example\")"
    ],
    "utterance": "Extract the value of the \"example\" field from the first object in the \"rows\" array in a file specified as script argument and store it in a shell variable.",
    "expressions": [
      "jq -j '.rows[].example' \"$file\""
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "example": "20"
            }
          ]
        },
        "output": "20"
      }
    ],
    "identifier": 45486380
  },
  {
    "context": [
      "jq --arg greeting world '{\"hello\":\"$greeting\"}' > file.json",
      "jq -n --arg greeting world '{\"hello\":\"$greeting\"}' > file.json",
      "the solution is \n\n    jq -n --arg greeting world '{\"hello\":$greeting}' > file.json",
      "you might want to use the \\() string interpolation syntax in your command. eg.\n\n    jq -n --arg greeting world '{\"hello\":\"\\($greeting)\"}'",
      "for me this produces\n\n    {\n      \"hello\": \"world\"\n    }"
    ],
    "utterance": "Create a file containing an object with a key 'hello' and value 'world', where the value is provided via a variable.",
    "expressions": [
      "jq -n --arg greeting world '{\"hello\":$greeting}'",
      "jq -n --arg greeting world '{\"hello\":\"\\($greeting)\"}'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "hello": "world"
        }
      }
    ],
    "identifier": 45469133
  },
  {
    "context": [
      "I think this will do what you want.",
      "[\n  .quantities as $q\n| .portions[]\n| .percentage as $p\n| {\n    customer,\n    quantities: [\n       $q[] | .quantity = .quantity * $p\n    ]\n  }\n]",
      "Since you indicated you want the Cartesian product, and that you only gave the sample output as being indicative of what you're looking for, it may be worth mentioning that one can obtain the Cartesian product very simply:",
      ".portions[] + .quantities[]",
      "For example, assuming .customer is always a string, we could transform\nthe input into the requested format as follows:",
      "def add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\n\n[.quantities[] + .portions[]]\n| map( {customer, quantities: {product, quantity: (.quantity * .percentage)}} )\n| add_by(.customer; .quantities)\n| to_entries\n| map( {customer: .key, quantities: .value })"
    ],
    "utterance": "For each portion, multiply its percentage by each product's quantity, grouping results by customer.",
    "expressions": [
      "[.quantities as $q | .portions[] | .percentage as $p | {customer, quantities: [$q[] | .quantity = .quantity * $p]}]",
      "def add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\n\n[.quantities[] + .portions[]]\n| map({customer, quantities: {product, quantity: (.quantity * .percentage)}})\n| add_by(.customer; .quantities)\n| to_entries\n| map({customer: .key, quantities: .value })"
    ],
    "data": [
      {
        "input": {
          "quantities": [
            {
              "product": "A",
              "quantity": 30
            },
            {
              "product": "B",
              "quantity": 10
            }
          ],
          "portions": [
            {
              "customer": "C1",
              "percentage": 0.6
            },
            {
              "customer": "C2",
              "percentage": 0.4
            }
          ]
        },
        "output": [
          {
            "customer": "C1",
            "quantities": [
              {
                "product": "A",
                "quantity": 18
              },
              {
                "product": "B",
                "quantity": 6
              }
            ]
          },
          {
            "customer": "C2",
            "quantities": [
              {
                "product": "A",
                "quantity": 12
              },
              {
                "product": "B",
                "quantity": 4
              }
            ]
          }
        ]
      }
    ],
    "identifier": 45382817
  },
  {
    "context": [
      "Here\u2019s my JSON:\r\n\r\n    {\r\n      \"data\": {\r\n        \"translations\": [\r\n          {\r\n            \"translatedText\": \"El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso.\"\r\n          }\r\n        ]\r\n      }\r\n    }",
      "I\u2019m trying to get just this part \"El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso.\" without quotes.",
      "The closest I got was with this: \r\n\r\n    .data.translations \r\n\r\n(but this fails to get what I\u2019m looking for)",
      "Consider also:\r\n\r\n    $ jq -r '.data.translations[].translatedText' input.json\r\n    El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso.",
      "or even:\r\n\r\n    jq -r '.data.translations[][]' input.json\r\n    El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso."
    ],
    "utterance": "Extract the translatedText value from the first (and only) object in data.translations as plain text output.",
    "expressions": [
      ".data.translations[].translatedText",
      ".data.translations[][]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "translations": [
              {
                "translatedText": "El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso."
              }
            ]
          }
        },
        "output": "El r\u0013pido zorro marr\u00003n salt\u000033 sobre el perro perezoso."
      }
    ],
    "identifier": 45491352
  },
  {
    "context": [
      "But when I do:\n    jq .response[].text file.json\nIt gives an error: Cannot index number with string \"text\"",
      "If your jq supports \"?\", then one possibility would be to use it:\n    .response[].text?",
      "Another would be to check the type explicitly, e.g.:\n    .response[] | objects | .text",
      "Yet another possibility:\n    .response[] | select(type==\"object\" and has(\"text\")) | .text"
    ],
    "utterance": "Extract all 'text' fields from objects inside the 'response' array, ignoring non-object items.",
    "expressions": [
      ".response[].text?",
      ".response[] | objects | .text",
      ".response[] | select(type==\"object\" and has(\"text\")) | .text"
    ],
    "data": [
      {
        "input": {
          "response": [
            1000,
            {
              "id": 1,
              "date": 123456,
              "owner_id": 7,
              "from_id": 5,
              "post_type": "post",
              "text": "blabla",
              "attachment": {
                "type": "photo",
                "photo": {
                  "pid": 12,
                  "aid": -7,
                  "owner_id": 3
                }
              }
            },
            {
              "id": 2,
              "date": 123457,
              "owner_id": 8,
              "from_id": 6,
              "post_type": "post",
              "text": "blabla2",
              "attachment": {
                "type": "link",
                "link": {
                  "url": "",
                  "title": "",
                  "description": "",
                  "target": "external"
                }
              }
            }
          ]
        },
        "output": [
          "blabla",
          "blabla2"
        ]
      }
    ],
    "identifier": 45523425
  },
  {
    "context": [
      "The json file was modified using jq with the filter \"{index: .[]}\" and the option -c since elasticsearch requires an entry to fit in a single line.",
      "Since the jq filter you specified is just `{index:.[]}`, jq is doing nothing to the part of the json elasticsearch is complaining about."
    ],
    "utterance": "Wrap each top-level element of an array as the value to an 'index' key, producing a compact object per line.",
    "expressions": [
      "{index: .[]}"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 1
          },
          {
            "bar": 2
          }
        ],
        "output": {
          "index": {
            "foo": 1
          }
        }
      }
    ],
    "identifier": 45510641
  },
  {
    "context": [
      "So, how can I process large files, of multiple JSON lines, and create one file for the input file that is generated as a single array, comma separated, without using slurp?",
      "The way you would do this with `inputs` is like this:\n\n```\njq -nR '[inputs | select(length>0)]' input.ndjson\n```\n\nThis will do it with streaming so you won't run into the slurp problem where the inputs all have to fit into memory.."
    ],
    "utterance": "Convert a file containing one object per line into a single array containing all objects as elements, efficiently for large files.",
    "expressions": [
      "jq -nR '[inputs | select(length>0)]' input.ndjson"
    ],
    "data": [
      {
        "input": "{ \"foo\": 1 }\n{ \"foo\": 2 }\n{ \"foo\": 3 }\n",
        "output": [
          {
            "foo": 1
          },
          {
            "foo": 2
          },
          {
            "foo": 3
          }
        ]
      }
    ],
    "identifier": 45456414
  },
  {
    "context": [
      "I have two objects with the same keys:\r\n\r\n    {\"key\": \"first_name\", \"value\": \"Jane\"}\r\n    {\"key\": \"last_name\", \"value\": \"Doe\"}\r\n\r\nand I want\r\n\r\n    {\"first_name\": \"Jane\", \"last_name\": \"Doe\"}\r\n\r\nHow can I do this in `jq`?",
      "jq 'map({(.key): .value}) | add' test.json",
      "jq -s 'reduce .[] as $o ({}; .[$o.key]=$o.value)' yourfile",
      "jq -s 'from_entries' yourfile"
    ],
    "utterance": "Convert an array of objects with 'key' and 'value' fields into a single object mapping those keys to values, such as [{'key':'first_name','value':'Jane'}, {'key':'last_name','value':'Doe'}] to {'first_name':'Jane','last_name':'Doe'}",
    "expressions": [
      "map({(.key): .value}) | add",
      "reduce .[] as $o ({}; .[$o.key]=$o.value)",
      "from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "key": "first_name",
            "value": "Jane"
          },
          {
            "key": "last_name",
            "value": "Doe"
          }
        ],
        "output": {
          "first_name": "Jane",
          "last_name": "Doe"
        }
      }
    ],
    "identifier": 45529418
  },
  {
    "context": [
      "However, I need to get just the VALUE field \"value\" as a bash array",
      "To fix your expanded example (the exact command), just don't use object construction {value: .Value}, but instead only .Value:",
      "$ readarray -t arr < <(aws ec2 describe-instances --region=us-east-1 --filters --filters \"Name=tag:NodeType,Values=worker\" --query \"Reservations[].Instances[].Tags[]\" | jq -r '.[] | select(.Key == \"NodeNumber\") | .Value')",
      "$ printf '%s\\n' \"${arr[@]}\"",
      "This might give you some ideas:",
      "done < <(jq -r '.value' json_file)"
    ],
    "utterance": "Extract the value field from each object and output all values as a flat list suitable for reading into a bash array.",
    "expressions": [
      ".value",
      "jq -r '.[] | select(.Key == \"NodeNumber\") | .Value'",
      "jq -r '.value' json_file"
    ],
    "data": [
      {
        "input": [
          {
            "value": "1"
          },
          {
            "value": "3"
          },
          {
            "value": "4"
          }
        ],
        "output": [
          "1",
          "3",
          "4"
        ]
      }
    ],
    "identifier": 45534673
  },
  {
    "context": [
      "I have \r\n\r\n    {\"a\":1} {\"b\":2}\r\n\r\nand I want to use `jq` to get\r\n\r\n    {\"a\": 1, \"b\":2}\r\n",
      "This produces the desired output.\r\n\r\n`jq -nc '[inputs] | add'`\r\n\r\nI can't say if it would work with jq.py, however.",
      "Less demanding on memory than using [inputs] would be:\r\n\r\n    reduce inputs as $in ({}; . + $in)\r\n\r\nThe above assumes the -n command-line option is in effect."
    ],
    "utterance": "Combine a sequence of objects with distinct keys into a single object containing all key-value pairs.",
    "expressions": [
      "[inputs] | add",
      "reduce inputs as $in ({}; . + $in)"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          }
        ],
        "output": {
          "a": 1,
          "b": 2
        }
      }
    ],
    "identifier": 45536418
  },
  {
    "context": [
      "I wish the same raw file, but the timestamps in human readable form.",
      "Drop the call to 'map'.",
      "'todate' expects its input to be numeric, so you will need to add a call to 'tonumber':",
      ".timestamp |= (tonumber|todate)"
    ],
    "utterance": "Convert the value of the 'timestamp' field from a numeric epoch (possibly as a string) to a human-readable date format, for each object in a stream.",
    "expressions": [
      ".timestamp |= (tonumber|todate)"
    ],
    "data": [
      {
        "input": {
          "timestamp": "1499779398.544612646",
          "source": "Galera Healthcheck",
          "message": "Galera Healthcheck.Opened DB connection",
          "log_level": 1,
          "data": {
            "dbHost": "0.0.0.0",
            "dbPort": 3306,
            "dbUser": "galera-healthcheck"
          }
        },
        "output": {
          "timestamp": "2017-07-11T13:43:18Z",
          "source": "Galera Healthcheck",
          "message": "Galera Healthcheck.Opened DB connection",
          "log_level": 1,
          "data": {
            "dbHost": "0.0.0.0",
            "dbPort": 3306,
            "dbUser": "galera-healthcheck"
          }
        }
      }
    ],
    "identifier": 45540191
  },
  {
    "context": [
      "Need to parse following for key, which have zipcodes == 73707802. For example, need to search for state key and name where one of the zipcodes is 73707802.So if I search for 73707802, it should return all names and keys (key name zipcode)",
      "Here is a solution that uses the `-r` and `--arg` options with **select** and **index**.",
      ".states[]\n| select(.city.zipcodes | index($zip|tonumber))\n| \"\\(.key) \\(.name) \\($zip)\"",
      "$ jq -r --arg zip 73707802 -f filter.jq data.json",
      "12 abc 73707802",
      "32 cde 73707802",
      "99 xyz 73707802"
    ],
    "utterance": "Find all states with a zipcode of 73707802, returning their key, name, and the searched zipcode.",
    "expressions": [
      ".states[] | select(.city.zipcodes | index($zip|tonumber)) | \"\\(.key) \\(.name) \\($zip)\""
    ],
    "data": [
      {
        "input": {
          "states": [
            {
              "key": "12",
              "name": "abc",
              "city": {
                "zipcodes": [
                  73707802,
                  71444504,
                  72646331,
                  73707802
                ]
              }
            },
            {
              "key": "32",
              "name": "cde",
              "city": {
                "zipcodes": [
                  71444504,
                  72646331,
                  73707802
                ]
              }
            },
            {
              "key": "99",
              "name": "xyz",
              "city": {
                "zipcodes": [
                  72754781,
                  71444504,
                  72646331,
                  73707802
                ]
              }
            }
          ]
        },
        "output": [
          "12 abc 73707802",
          "32 cde 73707802",
          "99 xyz 73707802"
        ]
      }
    ],
    "identifier": 45573261
  },
  {
    "context": [
      "I want to search by startswith",
      "There is a filter, 'startswith/0', but since you have gone to the trouble of using 'test/2' with the \"i\" option, let's stick with that:",
      "test(\"^A\"; \"i\")"
    ],
    "utterance": "Return all objects where the BPSNAM field starts with an 'A', matching case-insensitively.",
    "expressions": [
      ".[\"$resources\"] | .[] | select(.BPSNAM | test(\"^A\"; \"i\")) | .BPSNAM, .BPSNUM, .CUR"
    ],
    "data": [
      {
        "input": {
          "$itemsPerPage": 1208,
          "$resources": [
            {
              "$uuid": "7b44f5b6-a5bd-4c7a-8d4a-581ff36a1072",
              "$etag": "2016-08-12T12:29:33Z",
              "BPSNAM": "InfoCenter",
              "BPSNUM": "AO011",
              "BPSNUM_REF": {
                "$title": "InfoCenter",
                "$description": "InfoCenter"
              },
              "CUR": "AOA",
              "CUR_REF": {
                "$title": "Kwanza",
                "$description": "Angolan kwanza",
                "$symbol": "",
                "$scale": 2,
                "$precision": 11
              }
            },
            {
              "$uuid": "25ee60e6-dd55-4c0a-842d-8e66234342b8",
              "$etag": "2015-01-23T09:18:55Z",
              "BPSNAM": "NeoPneus - Componentes e Pneus",
              "BPSNUM": "AO051",
              "BPSNUM_REF": {
                "$title": "NeoPneus",
                "$description": "NeoPneus - Componentes e Pneus"
              },
              "CUR": "AOA",
              "CUR_REF": {
                "$title": "Kwanza",
                "$description": "Angolan kwanza",
                "$symbol": "",
                "$scale": 2,
                "$precision": 11
              }
            },
            {
              "$uuid": "00682755-d9c7-4755-928a-439f09555e77",
              "$etag": "2014-02-04T18:49:06Z",
              "BPSNAM": "SuperBikes - Acessorios",
              "BPSNUM": "AO052",
              "BPSNUM_REF": {
                "$title": "SuperBikes",
                "$description": "SuperBikes - Acessorios"
              },
              "CUR": "AOA",
              "CUR_REF": {
                "$title": "Kwanza",
                "$description": "Angolan kwanza",
                "$symbol": "",
                "$scale": 2,
                "$precision": 11
              }
            }
          ]
        }
      }
    ],
    "identifier": 45562926
  },
  {
    "context": [
      "What I need is a way to skip (yield empty) all items before the *n*th, and then output the rest as-is.",
      "def skip(n; stream):\n  foreach stream as $s (0; .+1; select(. > n) | $s);",
      "skip(1000; inputs)",
      "try (range(0; 1000) | input | empty), inputs"
    ],
    "utterance": "Skip the first 1000 items in a stream and output the rest.",
    "expressions": [
      "def skip(n; stream): foreach stream as $s (0; .+1; select(. > n) | $s); skip(1000; inputs)",
      "try (range(0; 1000) | input | empty), inputs"
    ],
    "identifier": 45580088
  },
  {
    "context": [
      "Given an input file with a series of keypairs, I want to select the 3rd-to-last and 4th-to-last pairs. I can get them individually, but I want to grab both at once if possible. Can this be done?",
      "My input file is structured like this;\n\n    [\n     {\n      \"foo\": \"bar\",\n      \"foo2\": \"bar2\"\n     },\n     {\n      \"foo3\": \"bar3\",\n      \"foo4\": \"bar4\"\n     },\n     {\n      \"foo5\": \"bar5\",\n      \"foo6\": \"bar6\"\n     },\n     {\n      \"foo7\": \"bar7\",\n      \"foo8\": \"bar8\"\n     },\n     {\n      \"foo9\": \"bar9\",\n      \"foo10\": \"bar10\"\n     }\n    ]",
      "And my output should be\n\n    [ \n     {\n      \"foo3\": \"bar3\",\n      \"foo4\": \"bar4\"\n     },\n     {\n      \"foo5\": \"bar5\",\n      \"foo6\": \"bar6\"\n     }\n    ]",
      "I know I can do `jq -s '.[-3]'` to get the 3rd-to-last (and swap with a 4 for the 4th-to-last) but that grabs them separately.",
      "I thought from the documentation that `jq -s '.[-3;-4]'` would grab both but that throws an error.",
      "The filter to use: [.[-3,-4]]",
      "`.[a,b]` is like `.[a],.[b]`.  The outer brackets turn this into an array.",
      "Any number of indices may be specified in this manner, and the order in which they are presented will determine the order of the items in the result.",
      "If you want to select ranges of values in an array, you could use the slice syntax:\n\n    <start-index>:<end-index>",
      "Just remember that the ending index is exclusive (and not inclusive) and should be increasing order.",
      "So to get the third/fourth from the end:\n\n    .[-4:-2]"
    ],
    "utterance": "Select the 4th-to-last and 3rd-to-last elements from an array, preserving their order.",
    "expressions": [
      ".[-4,-3]",
      ".[-4:-2]"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar",
            "foo2": "bar2"
          },
          {
            "foo3": "bar3",
            "foo4": "bar4"
          },
          {
            "foo5": "bar5",
            "foo6": "bar6"
          },
          {
            "foo7": "bar7",
            "foo8": "bar8"
          },
          {
            "foo9": "bar9",
            "foo10": "bar10"
          }
        ],
        "output": [
          {
            "foo3": "bar3",
            "foo4": "bar4"
          },
          {
            "foo5": "bar5",
            "foo6": "bar6"
          }
        ]
      }
    ],
    "identifier": 45548604
  },
  {
    "context": [
      "jq --raw-output \"(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv\" output2.json > output3.csv",
      "So the problem is likely in the exact command you're running.  Without seeing that it's difficult to say but putting your filter in a separate file would probably prevent any command-line quoting/escaping problems.",
      "Your `jq` script:\n*  **must be passed as a _literal_ PowerShell string (`'...'`)**, \n* because **an _interpolating_ PowerShell string (`\"...\"`) by design interprets `$`-prefixed tokens as _PowerShell_ variable references**",
      "jq -r '(map(keys) | add | unique) as $cols | \n           map(. as $row | $cols | map($row[.])) as $rows | \n             $cols, $rows[] | @csv' output2.json > output3.csv"
    ],
    "utterance": "Convert an array of objects with varying fields into CSV where the header contains all unique keys and each row contains the corresponding values, using PowerShell to ensure variable names with $ are not interpreted by the shell.",
    "expressions": [
      "(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "field1",
            "key2": "field2",
            "key3": "field3"
          },
          {
            "key1": "field4",
            "key2": "field5",
            "key3": "field6"
          }
        ],
        "output": [
          "\"key1\",\"key2\",\"key3\"",
          "\"field1\",\"field2\",\"field3\"",
          "\"field4\",\"field5\",\"field6\""
        ]
      }
    ],
    "identifier": 45579569
  },
  {
    "context": [
      "I want to use `jq` to decompose the tree into a flattened list whose format is such as below. This procedure should select one particular key in the hierarchy, the date, and for every instance of that date in the tree merge that date's values while making their key's unique based on the value's location in the tree:",
      "[ { \"date\" : \"20170405\", \"key00.key10.val0\" : 10, ... \"key00.key10.valn\" : 12 }, ... ]",
      "The remainder of the solution to the problem is based on the built-in filters `paths` and `group_by` ...",
      ". as $in\n| [paths \n   | select(length==4)\n   | . as $path\n   | [ $path, ($in|getpath($path)) ] ]\n| group_by( .[0][2] | tonumber )   # sort by numeric value\n| map( {date: .[0][0][2] }\n        + ( map( del(.[0][2]) | squish(\".\")) | add) )",
      "put that back into an array and use **group_by**, **reduce** and **setpath**",
      "[\n  to_entries\n| .[]\n| .key as $k1\n| ( .value | to_entries\n           | .[]\n           | .key as $k2\n           | ( .value | to_entries\n                      | .[]\n                      | .key as $d\n                      | ( .value | to_entries\n                                 | .[]\n                                 | [$d, [$k1, $k2, .key], .value]\n                        )                \n             )\n   )\n]",
      "| group_by(.[0])\n| .[]\n| .[0][0] as $d\n| reduce .[] as $e (\n      {date:$d}\n    ; setpath([$e[1] | join(\".\")]; $e[2])\n  )"
    ],
    "utterance": "Produce a flat list of objects where each object contains a unique date and all associated values as keys composed of their path in the nested structure, joined by dots.",
    "expressions": [
      "def squish(joinchar): { (.[0] | join(joinchar)): .[1] };\n. as $in\n| [paths \n   | select(length==4)\n   | . as $path\n   | [ $path, ($in|getpath($path)) ] ]\n| group_by( .[0][2] | tonumber )\n| map( {date: .[0][0][2] }\n        + ( map( del(.[0][2]) | squish(\".\")) | add) )",
      "[\n  to_entries\n| .[]\n| .key as $k1\n| ( .value | to_entries\n           | .[]\n           | .key as $k2\n           | ( .value | to_entries\n                      | .[]\n                      | .key as $d\n                      | ( .value | to_entries\n                                 | .[]\n                                 | [$d, [$k1, $k2, .key], .value]\n                        )                \n             )\n   )\n]\n| group_by(.[0])\n| .[]\n| .[0][0] as $d\n| reduce .[] as $e (\n      {date:$d}\n    ; setpath([$e[1] | join(\".\")]; $e[2])\n  )"
    ],
    "data": [
      {
        "input": {
          "key00": {
            "key10": {
              "20170405": {
                "val0": 10,
                "valn": 12
              },
              "20170404": {
                "val0": 5,
                "valn": 43
              }
            }
          },
          "key01": {
            "key11": {
              "20170405": {
                "val1": 1,
                "val2": 2
              },
              "20170406": {
                "val0": 0,
                "val9": 9
              }
            }
          }
        },
        "output": [
          {
            "date": "20170404",
            "key00.key10.val0": 5,
            "key00.key10.valn": 43
          },
          {
            "date": "20170405",
            "key00.key10.val0": 10,
            "key00.key10.valn": 12,
            "key01.key11.val1": 1,
            "key01.key11.val2": 2
          },
          {
            "date": "20170406",
            "key01.key11.val0": 0,
            "key01.key11.val9": 9
          }
        ]
      }
    ],
    "identifier": 45228619
  },
  {
    "context": [
      "id=`my_api myrouter myroutername getsomething'{\"uid\":\"$servername\",\"meta_type\":\"system\"}'| $SCRIPTS_DIR/jq -M '.result.data[].uid'`",
      "id=$(my_api myrouter myroutername getsomething'{\"uid\":\"'\"$servername\"'\",\"meta_type\":\"system\"}'| $SCRIPTS_DIR/jq -M '.result.data[].uid')"
    ],
    "utterance": "Extract the uid field from each object inside the data array under result.",
    "expressions": [
      ".result.data[].uid"
    ],
    "identifier": 45594724
  },
  {
    "context": [
      "> This includes the simplest command:",
      ">",
      "> jq -r . /path/to/json.json",
      "To ascertain the nature of the problem, it would probably be better to start with an even simpler command, such as:",
      "    jq -n ."
    ],
    "utterance": "Produce a single null value as output.",
    "expressions": [
      "jq -n ."
    ],
    "identifier": 45613545
  },
  {
    "context": [
      "I was thinking of taking template like this:",
      "'[{\"ParameterKey\":\"KEY\",\"ParameterValue\":\"VALUE\",\"UsePreviousValue\":false}]'",
      "jq --arg params 'key1,value1:key2,value2' then split on ':' to duplicate it and populate each with the comma separated values.",
      "Currently the best I've been able to do is this",
      "echo '[{\"ParameterKey\":\"KEY\",\"ParameterValue\":\"VALUE\",\"UsePreviousValue\":false}]' | jq --arg vars \"key1,val1:key2,val2\" '.[0].ParameterKey = ($vars|split(\":\")|.[]|split(\",\")|.[0]) | .[0].ParameterValue = ($vars|split(\":\")|.[]|split(\",\")|.[1])'",
      "But the output is a combination of all values (e.g. key1 val1, key1 val2, etc.)"
    ],
    "utterance": "Generate an array where each element is an object with ParameterKey and ParameterValue fields from a string like 'key1,val1:key2,val2', splitting on ':' for pairs and ',' for key and value, and setting UsePreviousValue to false.",
    "expressions": [
      "($vars | split(\":\") | map(split(\",\") | {ParameterKey: .[0], ParameterValue: .[1], UsePreviousValue: false}))"
    ],
    "data": [
      {
        "input": {
          "vars": "key1,val1:key2,val2"
        },
        "output": [
          {
            "ParameterKey": "key1",
            "ParameterValue": "val1",
            "UsePreviousValue": false
          },
          {
            "ParameterKey": "key2",
            "ParameterValue": "val2",
            "UsePreviousValue": false
          }
        ]
      }
    ],
    "identifier": 45592982
  },
  {
    "context": [
      "I have four files:",
      "input.json",
      "keyfile.json",
      "vault.json",
      "vault.jq",
      "reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))",
      "jq --argfile keyfile keyfile.json --argfile vault vault.json -f vault.jq input.json > desired.json",
      "I'm not coding the keyfile.json file correctly, because I am not getting the desired results.",
      "I believe it's just the syntax used in your keyfile - It is causing a string literal \"value[0]\" to be created instead of the array index 0 being referenced in the path substitution.",
      "Try use the syntax",
      "\"value\",0,\"account_name\"",
      "Using the below as keyfile.json:",
      "[ [ [\"properties.on_demand_service_plans_collection\", \"value\",0, \"account_name\"], [\"appd\", \"account_name\"]], [ [\"properties.on_demand_service_plans_collection\", \"value\",0, \"account_access_key\"], [\"appd\", \"account_key\"] ], [ [\"properties.on_demand_service_plans_collection\", \"value\",1, \"account_name\"], [\"appd\", \"account_name\"] ], [ [\"properties.on_demand_service_plans_collection\", \"value\",1, \"account_access_key\"], [\"appd\", \"account_key\"] ] ]",
      "Produces desired.json:"
    ],
    "utterance": "Update specific keys in nested objects based on path mappings from one JSON file to values in another, using correct array index paths instead of string indices.",
    "expressions": [
      "reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))"
    ],
    "data": [
      {
        "input": {
          "input.json": {
            ".properties.on_demand_service_plans_collection": {
              "type": "collection",
              "value": [
                {
                  "plan_name": "my-plan",
                  "plan_description": "my-plan",
                  "account_name": "vault-supplied-value",
                  "account_access_key": "vault-supplied-value"
                },
                {
                  "plan_name": "my-plan-test",
                  "plan_description": "my-plan-test",
                  "account_name": "vault-supplied-value",
                  "account_access_key": "vault-supplied-value"
                }
              ],
              "optional": false
            }
          },
          "vault.json": {
            "appd": {
              "account_key": "appd-key",
              "account_name": "appd-user"
            },
            "aws": {
              "access_key_id": "my-key-id",
              "region": "us-east-1",
              "secret_access_key": "my-secret-key"
            }
          },
          "keyfile.json": [
            [
              [
                "properties.on_demand_service_plans_collection",
                "value",
                0,
                "account_name"
              ],
              [
                "appd",
                "account_name"
              ]
            ],
            [
              [
                "properties.on_demand_service_plans_collection",
                "value",
                0,
                "account_access_key"
              ],
              [
                "appd",
                "account_key"
              ]
            ],
            [
              [
                "properties.on_demand_service_plans_collection",
                "value",
                1,
                "account_name"
              ],
              [
                "appd",
                "account_name"
              ]
            ],
            [
              [
                "properties.on_demand_service_plans_collection",
                "value",
                1,
                "account_access_key"
              ],
              [
                "appd",
                "account_key"
              ]
            ]
          ]
        },
        "output": {
          ".properties.on_demand_service_plans_collection": {
            "type": "collection",
            "value": [
              {
                "plan_name": "my-plan",
                "plan_description": "my-plan",
                "account_name": "appd-user",
                "account_access_key": "appd-key"
              },
              {
                "plan_name": "my-plan-test",
                "plan_description": "my-plan-test",
                "account_name": "appd-user",
                "account_access_key": "appd-key"
              }
            ],
            "optional": false
          }
        }
      }
    ],
    "identifier": 45472525
  },
  {
    "context": [
      "how to convert multiple json object into one object using jq?",
      "Input:",
      "{\n  \"ip\": {\n    \"ip_ip_dst\": \"4.2.2.2\",\n    \"ip_ip_src\": \"192.168.2.208\"\n  },\n  \"dns\": {\n    \"text_dns_qry_class\": \"0x00000001\",\n    \"text_dns_a\": \"104.199.136.182\",\n    \"text_dns_qry_name_len\": \"15\",\n    \"text_dns_qry_name\": \"vehere.odoo.com\",\n    \"text_dns_resp_type\": \"1\",\n    \"text_dns_qry_type\": \"1\"\n  },\n  \"frame\": {\n    \"frame_frame_len\": \"79\",\n    \"frame_frame_time\": \"Aug 9, 2017 13:21:29.987979869 IST\"\n  }\n}\n",
      "Output should be:",
      "{\n    \"ip_ip_dst\": \"4.2.2.2\",\n    \"ip_ip_src\": \"192.168.2.208\"\n    \"text_dns_qry_class\": \"0x00000001\",\n    \"text_dns_a\": \"104.199.136.182\",\n    \"text_dns_qry_name_len\": \"15\",\n    \"text_dns_qry_name\": \"vehere.odoo.com\",\n    \"text_dns_resp_type\": \"1\",\n    \"text_dns_qry_type\": \"1\"\n    \"frame_frame_len\": \"79\",\n    \"frame_frame_time\": \"Aug 9, 2017 13:21:29.987979869 IST\"\n  \n}",
      "You are looking for the `add` function:\n\n    jq 'add' file.json",
      "[.[]] | add\n\nshould do the trick."
    ],
    "utterance": "Flatten all nested objects at the top level into a single object containing all key-value pairs from those nested objects.",
    "expressions": [
      "[.[]] | add",
      "add"
    ],
    "data": [
      {
        "input": {
          "ip": {
            "ip_ip_dst": "4.2.2.2",
            "ip_ip_src": "192.168.2.208"
          },
          "dns": {
            "text_dns_qry_class": "0x00000001",
            "text_dns_a": "104.199.136.182",
            "text_dns_qry_name_len": "15",
            "text_dns_qry_name": "vehere.odoo.com",
            "text_dns_resp_type": "1",
            "text_dns_qry_type": "1"
          },
          "frame": {
            "frame_frame_len": "79",
            "frame_frame_time": "Aug 9, 2017 13:21:29.987979869 IST"
          }
        },
        "output": {
          "ip_ip_dst": "4.2.2.2",
          "ip_ip_src": "192.168.2.208",
          "text_dns_qry_class": "0x00000001",
          "text_dns_a": "104.199.136.182",
          "text_dns_qry_name_len": "15",
          "text_dns_qry_name": "vehere.odoo.com",
          "text_dns_resp_type": "1",
          "text_dns_qry_type": "1",
          "frame_frame_len": "79",
          "frame_frame_time": "Aug 9, 2017 13:21:29.987979869 IST"
        }
      }
    ],
    "identifier": 45609601
  },
  {
    "context": [
      "How can I use `jq` to retain all of the JSON structure, but filter out some of the children using `select()`. For instance, If I wanted to return only children with country GB, I would expect the following output:",
      "If I only want the children, this is easy with `.children[] | select(.properties.country == \"GB\")`, but does not retain the rest of the JSON.",
      "The key is to use `|=`.  In the present case, you could use the following pattern:",
      ".children |= map(select(...))"
    ],
    "utterance": "Return the entire structure, but only include children whose properties.country is \"GB\".",
    "expressions": [
      ".children |= map(select(.properties.country == \"GB\"))"
    ],
    "data": [
      {
        "input": {
          "type": "collection",
          "foo": "bar",
          "children": [
            {
              "properties": {
                "country": "GB"
              },
              "data": "..."
            },
            {
              "properties": {
                "country": "PL"
              },
              "data": "..."
            }
          ]
        },
        "output": {
          "type": "collection",
          "foo": "bar",
          "children": [
            {
              "properties": {
                "country": "GB"
              },
              "data": "..."
            }
          ]
        }
      }
    ],
    "identifier": 45632645
  },
  {
    "context": [
      "I have a json file with the following format:\r\n\r\n    {userid: 1, client_visited: [1001, 1002]}\r\n    {userid: 2, client_visited: [1001, 1004]}\r\n    {userid: 3, client_visited: [1004, 1006]}\r\n    {userid: 4, client_visited: [1003, 1005, 1006]}\r\n    {userid: 5, client_visited: [1006]}\r\n\r\nI have a mapping of clients that is output from MYSQL db:\r\n\r\n    {\"1001\": a, \"1002\": b, \"1003\": c, \"1004\": d, \"1005\": e, \"1006\": f}\r\n\r\nHow can I update the above json file for the following output?\r\n\r\n    {userid: 1, client_visited: ['a', 'b']}\r\n    {userid: 2, client_visited: ['a', 'd']}\r\n    {userid: 3, client_visited: ['d', 'f']}\r\n    {userid: 4, client_visited: ['c', 'e', 'f']}\r\n    {userid: 5, client_visited: ['f']}\r\n\r\nI am looking at `jq` command to achieve this in a shell script.",
      ".client_visited |= map(dict[tostring])",
      ".client_visited |= map(tostring as $s | if dict|has($s) then dict[$s] else 0 end)",
      ".client_visited |= map(dict[tostring] // 0)",
      "reduce (.client_visited|range(length)) as $i (. ; .client_visited[$i] |= $arg[tostring])"
    ],
    "utterance": "Replace each number in the client_visited array with the corresponding value from a mapping object, converting numbers to strings for lookups.",
    "expressions": [
      ".client_visited |= map(dict[tostring])",
      ".client_visited |= map(tostring as $s | if dict|has($s) then dict[$s] else 0 end)",
      ".client_visited |= map(dict[tostring] // 0)",
      "reduce (.client_visited|range(length)) as $i (. ; .client_visited[$i] |= $arg[tostring])"
    ],
    "data": [
      {
        "input": [
          {
            "userid": 1,
            "client_visited": [
              1001,
              1002
            ]
          },
          {
            "userid": 2,
            "client_visited": [
              1001,
              1004
            ]
          },
          {
            "userid": 3,
            "client_visited": [
              1004,
              1006
            ]
          },
          {
            "userid": 4,
            "client_visited": [
              1003,
              1005,
              1006
            ]
          },
          {
            "userid": 5,
            "client_visited": [
              1006
            ]
          }
        ],
        "output": [
          {
            "userid": 1,
            "client_visited": [
              "a",
              "b"
            ]
          },
          {
            "userid": 2,
            "client_visited": [
              "a",
              "d"
            ]
          },
          {
            "userid": 3,
            "client_visited": [
              "d",
              "f"
            ]
          },
          {
            "userid": 4,
            "client_visited": [
              "c",
              "e",
              "f"
            ]
          },
          {
            "userid": 5,
            "client_visited": [
              "f"
            ]
          }
        ]
      }
    ],
    "identifier": 45613775
  },
  {
    "context": [
      "\"The JSON structure looks something like this: ... Each level contains an `Array` of `courses`, each of which is a `Dictionary`, containing an `Array` of `lesson` dictionaries.\"",
      "\"for level in levels { ... let title = lesson[\\\"title\\\"]; let videoURL = lesson[\\\"url\\\"]; ... }\"",
      "\"Code to extract the titles and URLs into distinct shell variables may look like:\\n\\n    jq_program='\\n    .items[].playlists[]            # we only care about playlist contents\\n    | .title as $level_title        # store the level title before recursing\\n    | .courses[]                    # ...into elements of the array in .courses...\\n    | .title as $course_title       # repeat to store the course title\\n    | .lessons[]                    # ...before recursing into the lesson...\\n    # ...and emitting the stored level and course titles, plus the lesson title and url\\n    | [$level_title, $course_title, .title, .url] | @tsv                              \\n    '\","
    ],
    "utterance": "Extract each level title, course title, lesson title, and lesson url as flat records",
    "expressions": [
      ".items[].playlists[] | .title as $level_title | .courses[] | .title as $course_title | .lessons[] | [$level_title, $course_title, .title, .url]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "playlists": [
                {
                  "title": "Level One Title",
                  "courses": [
                    {
                      "title": "Level One Course One Title",
                      "lessons": [
                        {
                          "title": "lesson 1 title",
                          "url": "lesson 1 url"
                        },
                        {
                          "title": "lesson 2 title",
                          "url": "lesson 2 url"
                        }
                      ]
                    },
                    {
                      "title": "Level One Course Two Title",
                      "lessons": [
                        {
                          "title": "lesson 1 title",
                          "url": "lesson 1 url"
                        },
                        {
                          "title": "lesson 2 title",
                          "url": "lesson 2 url"
                        }
                      ]
                    }
                  ]
                },
                {
                  "title": "Level Two Title",
                  "courses": [
                    {
                      "title": "Level Two Course One Title",
                      "lessons": [
                        {
                          "title": "lesson 1 title",
                          "url": "lesson 1 url"
                        },
                        {
                          "title": "lesson 2 title",
                          "url": "lesson 2 url"
                        }
                      ]
                    },
                    {
                      "title": "Level Two Course Two Title",
                      "lessons": [
                        {
                          "title": "lesson 1 title",
                          "url": "lesson 1 url"
                        },
                        {
                          "title": "lesson 2 title",
                          "url": "lesson 2 url"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          [
            "Level One Title",
            "Level One Course One Title",
            "lesson 1 title",
            "lesson 1 url"
          ],
          [
            "Level One Title",
            "Level One Course One Title",
            "lesson 2 title",
            "lesson 2 url"
          ],
          [
            "Level One Title",
            "Level One Course Two Title",
            "lesson 1 title",
            "lesson 1 url"
          ],
          [
            "Level One Title",
            "Level One Course Two Title",
            "lesson 2 title",
            "lesson 2 url"
          ],
          [
            "Level Two Title",
            "Level Two Course One Title",
            "lesson 1 title",
            "lesson 1 url"
          ],
          [
            "Level Two Title",
            "Level Two Course One Title",
            "lesson 2 title",
            "lesson 2 url"
          ],
          [
            "Level Two Title",
            "Level Two Course Two Title",
            "lesson 1 title",
            "lesson 1 url"
          ],
          [
            "Level Two Title",
            "Level Two Course Two Title",
            "lesson 2 title",
            "lesson 2 url"
          ]
        ]
      }
    ],
    "identifier": 45617267
  },
  {
    "context": [
      "I actually looking for an solution to merge several (3-4) arrays based on several \"index\" keys.",
      "DegreesIndex and Schoolindex refers to two different Keys in two other Arrays:",
      "How can i merge that arrays based on the \"index\" keys with JQ 1.5 under windows10?",
      "# input: an object\ndef merge_by_index(obj; ix):\n  ix as $index\n  | . + (obj | map( select( ix == $index)) [0] )\n  | del(ix) ;",
      "a1\n| .Fan[0] |= merge_by_index(a2|.Degrees; .DegreesIndex)\n| .Fan[0] |= merge_by_index(a3|.School; .SchoolIndex)",
      "def LookupDegrees($i):\n  [\n      array2\n    | .Degrees[]\n    | select(.DegreesIndex == $i)\n  ][0]\n;",
      "def LookupSchool($i):\n  [\n      array3\n    | .School[]\n    | select(.SchoolIndex == $i)\n  ][0]\n;",
      "array1\n| .Fan[] \n| .Degrees = LookupDegrees(.DegreesIndex)\n| .School = LookupSchool(.SchoolIndex)"
    ],
    "utterance": "Merge multiple arrays by associating objects from a main array with data from two other arrays using matching index keys (DegreesIndex and SchoolIndex).",
    "expressions": [
      "def merge_by_index(obj; ix): ix as $index | . + (obj | map(select(ix == $index))[0]) | del(ix); a1 | .Fan[0] |= merge_by_index(a2|.Degrees; .DegreesIndex) | .Fan[0] |= merge_by_index(a3|.School; .SchoolIndex)",
      "def LookupDegrees($i): [ array2 | .Degrees[] | select(.DegreesIndex == $i) ][0]; def LookupSchool($i): [ array3 | .School[] | select(.SchoolIndex == $i) ][0]; array1 | .Fan[] | .Degrees = LookupDegrees(.DegreesIndex) | .School = LookupSchool(.SchoolIndex)"
    ],
    "data": [
      {
        "input": {
          "Fan": [
            {
              "Last Name": "Mueller",
              "Firstname": "Martin",
              "Adress": "Madisson Square",
              "City": "New York",
              "DegreesIndex": 3,
              "SchoolIndex": 1
            }
          ]
        },
        "output": {
          "Fan": [
            {
              "Last Name": "Mueller",
              "Firstname": "Martin",
              "Adress": "Madisson Square",
              "City": "New York",
              "Key": 12759303,
              "Degrees": 1.6,
              "Teaser": 12759303.8,
              "Trainer": "Miller"
            }
          ]
        }
      },
      {
        "input": {
          "array1": {
            "Fan": [
              {
                "Last Name": "Mueller",
                "First Name": "Martin",
                "Address": "Madisson Square",
                "City": "New York",
                "DegreesIndex": 3,
                "SchoolIndex": 1
              },
              {
                "Last Name": "Roberts",
                "First Name": "Bob",
                "DegreesIndex": 2,
                "SchoolIndex": 4
              },
              {
                "Last Name": "Skywalker",
                "First Name": "Luke",
                "DegreesIndex": 5,
                "SchoolIndex": 1
              }
            ]
          },
          "array2": {
            "Degrees": [
              {
                "DegreesIndex": 3,
                "Key": "12759303",
                "Degrees": 1.6
              },
              {
                "DegreesIndex": 2,
                "Key": "2",
                "Degrees": 2
              }
            ]
          },
          "array3": {
            "School": [
              {
                "SchoolIndex": 1,
                "Teaser": "12759303.8",
                "Trainer": "Miller"
              },
              {
                "SchoolIndex": 2,
                "Teaser": "2",
                "Trainer": "Miller"
              }
            ]
          }
        },
        "output": [
          {
            "Last Name": "Mueller",
            "First Name": "Martin",
            "Address": "Madisson Square",
            "City": "New York",
            "DegreesIndex": 3,
            "SchoolIndex": 1,
            "Degrees": {
              "DegreesIndex": 3,
              "Key": "12759303",
              "Degrees": 1.6
            },
            "School": {
              "SchoolIndex": 1,
              "Teaser": "12759303.8",
              "Trainer": "Miller"
            }
          },
          {
            "Last Name": "Roberts",
            "First Name": "Bob",
            "DegreesIndex": 2,
            "SchoolIndex": 4,
            "Degrees": {
              "DegreesIndex": 2,
              "Key": "2",
              "Degrees": 2
            },
            "School": null
          },
          {
            "Last Name": "Skywalker",
            "First Name": "Luke",
            "DegreesIndex": 5,
            "SchoolIndex": 1,
            "Degrees": null,
            "School": {
              "SchoolIndex": 1,
              "Teaser": "12759303.8",
              "Trainer": "Miller"
            }
          }
        ]
      }
    ],
    "identifier": 45419527
  },
  {
    "context": [
      "I\u2019m trying to add a new key/value under `successfulSet[].event` (key name as `affectedEntities`) using jq",
      "The value of the new key that I want to add is stored in a variable called `$affected_entities` and a sample of that value looks like this:\n[\n    \"arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx\"\n]",
      "Try this:\n\n    jq --argjson argval \"$new_value\" '.successfulSet[].event += { \"affected_entities\" : $argval }' file.json"
    ],
    "utterance": "Add a new key 'affected_entities' with an array value stored in a variable to each 'event' object within 'successfulSet'.",
    "expressions": [
      "jq --argjson argval \"$new_value\" '.successfulSet[].event += { \"affected_entities\" : $argval }'"
    ],
    "data": [
      {
        "input": {
          "failedSet": [],
          "successfulSet": [
            {
              "event": {
                "arn": "arn:aws:health:us-east-1::event/AWS_RDS_MAINTENANCE_SCHEDULED_xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxx",
                "endTime": 1502841540.0,
                "eventTypeCategory": "scheduledChange",
                "eventTypeCode": "AWS_RDS_MAINTENANCE_SCHEDULED",
                "lastUpdatedTime": 1501208541.93,
                "region": "us-east-1",
                "service": "RDS",
                "startTime": 1502236800.0,
                "statusCode": "open"
              },
              "eventDescription": {
                "latestDescription": "We are contacting you to inform you that one or more of your Amazon RDS DB instances is scheduled to receive system upgrades during your maintenance window between August 8 5:00 PM and August 15 4:59 PM PDT. Please see the affected resource tab for a list of these resources. \\r\\n\\r\\nWhile the system upgrades are in progress, Single-AZ deployments will be unavailable for a few minutes during your maintenance window. Multi-AZ deployments will be unavailable for the amount of time it takes a failover to complete, usually about 60 seconds, also in your maintenance window. \\r\\n\\r\\nPlease ensure the maintenance windows for your affected instances are set appropriately to minimize the impact of these system upgrades. \\r\\n\\r\\nIf you have any questions or concerns, contact the AWS Support Team. The team is available on the community forums and by contacting AWS Premium Support. \\r\\n\\r\\nhttp://aws.amazon.com/support\\r\\n"
              }
            }
          ]
        },
        "output": {
          "failedSet": [],
          "successfulSet": [
            {
              "event": {
                "arn": "arn:aws:health:us-east-1::event/AWS_RDS_MAINTENANCE_SCHEDULED_xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxx",
                "endTime": 1502841540.0,
                "eventTypeCategory": "scheduledChange",
                "eventTypeCode": "AWS_RDS_MAINTENANCE_SCHEDULED",
                "lastUpdatedTime": 1501208541.93,
                "region": "us-east-1",
                "service": "RDS",
                "startTime": 1502236800.0,
                "statusCode": "open",
                "affected_entities": [
                  "arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx"
                ]
              },
              "eventDescription": {
                "latestDescription": "We are contacting you to inform you that one or more of your Amazon RDS DB instances is scheduled to receive system upgrades during your maintenance window between August 8 5:00 PM and August 15 4:59 PM PDT. Please see the affected resource tab for a list of these resources. \\r\\n\\r\\nWhile the system upgrades are in progress, Single-AZ deployments will be unavailable for a few minutes during your maintenance window. Multi-AZ deployments will be unavailable for the amount of time it takes a failover to complete, usually about 60 seconds, also in your maintenance window. \\r\\n\\r\\nPlease ensure the maintenance windows for your affected instances are set appropriately to minimize the impact of these system upgrades. \\r\\n\\r\\nIf you have any questions or concerns, contact the AWS Support Team. The team is available on the community forums and by contacting AWS Premium Support. \\r\\n\\r\\nhttp://aws.amazon.com/support\\r\\n"
              }
            }
          ]
        }
      }
    ],
    "identifier": 45628947
  },
  {
    "context": [
      "and my output has to be:\r\n\r\n    [{\"name\":\"Joe _ item1\",\"code\": }]\r\n    [{\"name\":\"Joe _ item2\",\"code\": }]\r\n    [{\"name\":\"Jim _ item3\",\"code\":gst-70}]\r\n    [{\"name\":\"Jim _ item4\",\"code\":gst-50}]\r\n",
      "The output, however, is valid JSON.\r\n\r\n    .item[]\r\n    | .name as $name\r\n    | .item[]\r\n    | {name: \"\\($name) _ \\(.name1)\",\r\n       code: (if .event then .event[].script.exec[0]|split(\"=\")[1]\r\n              else null end) }\r\n",
      "With your input, this produces:\r\n\r\n    {\"name\":\"Joe _ item1\",\"code\":null}\r\n    {\"name\":\"Joe _ item2\",\"code\":null}\r\n    {\"name\":\"Jim _ item3\",\"code\":\"gst-70\"}\r\n    {\"name\":\"Jim _ item4\",\"code\":\"gst-50\"}\r\n"
    ],
    "utterance": "Produce an array of objects for each sub-item, with the name as the parent 'name' and sub-item 'name1' joined by ' _ ', and code as the value after '=' in 'event[].script.exec[0]' if it exists, or null otherwise.",
    "expressions": [
      ".item[] | .name as $name | .item[] | {name: \"\u007f($name) _ \u007f(.name1)\", code: (if .event then .event[].script.exec[0]|split(\"=\")[1] else null end) }",
      ".item[] | .name as $name | .item[] | {name: \"\u007f($name) _ \u007f(.name1)\", code: (if .event then (.event[].script.exec[0] | sub(\"^[^=]*=\", \"\")) else null end) }"
    ],
    "data": [
      {
        "input": {
          "variables": [],
          "item": [
            {
              "name": "Joe",
              "item": [
                {
                  "name1": "item1",
                  "request": {},
                  "response": []
                },
                {
                  "name1": "item2",
                  "request": {},
                  "response": []
                }
              ]
            },
            {
              "name": "Jim",
              "item": [
                {
                  "name1": "item3",
                  "event": [
                    {
                      "listen": "test",
                      "script": {
                        "type": "text/javascript",
                        "exec": [
                          "//code=gst-70"
                        ]
                      }
                    }
                  ],
                  "request": {},
                  "response": []
                },
                {
                  "name1": "item4",
                  "event": [
                    {
                      "listen": "test",
                      "script": {
                        "type": "text/javascript",
                        "exec": [
                          "//code=gst-50"
                        ]
                      }
                    }
                  ],
                  "request": {},
                  "response": []
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "Joe _ item1",
            "code": null
          },
          {
            "name": "Joe _ item2",
            "code": null
          },
          {
            "name": "Jim _ item3",
            "code": "gst-70"
          },
          {
            "name": "Jim _ item4",
            "code": "gst-50"
          }
        ]
      }
    ],
    "identifier": 45656255
  },
  {
    "context": [
      "Let us assume 3 `package.json` files were found.  The `dependencies` and `devDependencies` are different but must be combined",
      "... would all be combined to make the following file:",
      "{\n  \"name\":\"project-c\",\n  \"dependencies\":{\n    \"module-a\":\"1.2.3\",\n    \"module-b\":\"2.3.4\"\n  },\n  \"devDependencies\":{\n    \"gulp\":\"*\"\n  }\n}",
      "The `name` property, in the final output file, is irrelevant.  The key here is the merge of the `dependencies` and `devDependencies` objects.",
      "Here is a solution which uses the jq **`*`** operator along with **reduce** and the `-s` option to merge the objects:",
      "jq -s 'reduce .[] as $d ({}; . *= $d)' $(find ../../projects -name package.json)",
      "If your jq has `inputs`, here is a more efficient solution than is possible using the -s (\"slurp\") option:",
      "reduce inputs as $i ({};\n  .dependencies += ($i | .dependencies )\n  | .devDependencies += ($i | .devDependencies ) )",
      "This also produces a \"clean\" result (i.e., no \"name\" field)."
    ],
    "utterance": "Combine multiple files so that the dependencies and devDependencies objects are deeply merged and the name field is omitted in the result.",
    "expressions": [
      "jq -s 'reduce .[] as $d ({}; . *= $d)' $(find ../../projects -name package.json)",
      "find ../../projects -name package.json -exec cat {} \\; | jq -M -s 'reduce .[] as $d ({}; . *= $d)'",
      "jq -n 'reduce inputs as $i ({}; .dependencies += ($i | .dependencies) // {}; .devDependencies += ($i | .devDependencies) // {})' $(find ../../projects -name package.json)",
      "jq -s 'map([.dependencies, .devDependencies]) | transpose | map(add) | {dependencies: .[0], devDependencies: .[1]}' $(find ../../projects -name package.json)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "project-a",
            "dependencies": {
              "module-a": "1.2.3"
            }
          },
          {
            "name": "project-b",
            "dependencies": {
              "module-b": "2.3.4"
            }
          },
          {
            "name": "project-c",
            "devDependencies": {
              "gulp": "*"
            }
          }
        ],
        "output": {
          "dependencies": {
            "module-a": "1.2.3",
            "module-b": "2.3.4"
          },
          "devDependencies": {
            "gulp": "*"
          }
        }
      }
    ],
    "identifier": 45681136
  },
  {
    "context": [
      "I am expecting an output something like this (for bitwise OR operation on the elements of client array):",
      "Here is a jq solution.",
      ".clients = (.clients | map(base2powers) | combine)",
      ".clients = (\n      .clients\n    | [max|twopowers_v3] as $powers\n    | map(base2powers_v2($powers))\n    | transpose\n    | map(max)\n    | add\n )",
      "The following builds on the two generic filters (`convert/1` and `to_i/1`) available at https://rosettacode.org/wiki/Non-decimal_radices/Convert#jq\nTheir definitions are included below for completeness and ease of reference.",
      ".clients |= bitwise_or",
      "Here is a stand-alone, efficient solution that only assumes the availability of jq 1.4 or later. It defines two generic functions: `elementwise/1` and `bitwise_or/0`:",
      ".clients |= bitwise_or"
    ],
    "utterance": "Replace the clients array in each object with the result of a bitwise OR operation applied to all its elements.",
    "expressions": [
      ".clients = (.clients | map(base2powers) | combine)",
      ".clients = (\n      .clients\n    | [max|twopowers_v3] as $powers\n    | map(base2powers_v2($powers))\n    | transpose\n    | map(max)\n    | add\n )",
      ".clients |= bitwise_or"
    ],
    "data": [
      {
        "input": {
          "userid": "04f",
          "clients": [
            1,
            2
          ]
        },
        "output": {
          "userid": "04f",
          "clients": 3
        }
      },
      {
        "input": {
          "userid": "07f",
          "clients": [
            1,
            6,
            7
          ]
        },
        "output": {
          "userid": "07f",
          "clients": 7
        }
      },
      {
        "input": {
          "userid": "082",
          "clients": [
            2,
            6,
            1
          ]
        },
        "output": {
          "userid": "082",
          "clients": 7
        }
      },
      {
        "input": {
          "userid": "0c1",
          "clients": [
            3,
            9,
            8
          ]
        },
        "output": {
          "userid": "0c1",
          "clients": 11
        }
      },
      {
        "input": {
          "userid": "13f",
          "clients": [
            4
          ]
        },
        "output": {
          "userid": "13f",
          "clients": 4
        }
      }
    ],
    "identifier": 45616953
  },
  {
    "context": [
      "The final list of snapshots should be older than 60 days. I can discern their age via their `SnapshotCreateTime`, but I need their `DBSnapshotIdentifier` value to be able to delete them.",
      "select(.SnapshotCreateTime | sub(\"\\\\.[0-9]*\";\"\") < (ago(60) | todate)) | .DBSnapshotIdentifier",
      "def too_old:\n    select(   .SnapshotCreateTime\n            | sub(\"[.][0-9]+Z\";\"Z\")   # remove fractional seconds\n            | fromdate                # convert to unix time\n            | now - .                 # convert to age in seconds\n            | . >  (86400 * 60)       # true if older than 60 days in seconds\n    )\n;\n\n  too_old\n| .DBSnapshotIdentifier"
    ],
    "utterance": "List the DBSnapshotIdentifier values of snapshots whose SnapshotCreateTime is more than 60 days ago.",
    "expressions": [
      "select(.SnapshotCreateTime | sub(\"\\\\.[0-9]*\";\"\") < (now - (60*24*3600) | todate)) | .DBSnapshotIdentifier",
      "def too_old:\n    select(   .SnapshotCreateTime\n            | sub(\"[.][0-9]+Z\";\"Z\")   # remove fractional seconds\n            | fromdate\n            | now - . > (86400 * 60)\n    );\n\ntoo_old | .DBSnapshotIdentifier"
    ],
    "data": [
      {
        "input": [
          {
            "Engine": "postgres",
            "SnapshotCreateTime": "2017-08-22T16:35:42.302Z",
            "AvailabilityZone": "us-east-1b",
            "DBSnapshotIdentifier": "alex2-20170822-0108-bkup",
            "AllocatedStorage": 5
          },
          {
            "Engine": "postgres",
            "SnapshotCreateTime": "2017-06-02T16:35:42.302Z",
            "AvailabilityZone": "us-east-1a",
            "DBSnapshotIdentifier": "alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9",
            "AllocatedStorage": 5
          },
          {
            "Engine": "postgres",
            "SnapshotCreateTime": "2017-04-22T16:35:42.302Z",
            "AvailabilityZone": "us-east-1a",
            "DBSnapshotIdentifier": "alex3-20170422-update",
            "AllocatedStorage": 5
          }
        ],
        "output": [
          "alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9",
          "alex3-20170422-update"
        ]
      }
    ],
    "identifier": 45700109
  },
  {
    "context": [
      "This one allows you to split putRequest to set of arrays having no more than 2 items",
      "jq -c \"[ .MusicCollection[] ] | range(0; length; 2) as $i | { MusicCollection: .[ $i:$i+2 ] }\" input.json",
      "jq -c --argjson L \"!ARRAYLENGTH!\" \"[ .MusicCollection[] ] | range(0; length; $L) as $i | { MusicCollection: .[ $i:$i+$L ] }\" input.json"
    ],
    "utterance": "Split the MusicCollection array into multiple objects, each containing at most 2 items.",
    "expressions": [
      "jq -c \"[ .MusicCollection[] ] | range(0; length; 2) as $i | { MusicCollection: .[ $i:$i+2 ] }\" input.json",
      "jq -c --argjson L \"!ARRAYLENGTH!\" \"[ .MusicCollection[] ] | range(0; length; $L) as $i | { MusicCollection: .[ $i:$i+$L ] }\" input.json"
    ],
    "data": [
      {
        "input": {
          "MusicCollection": [
            {
              "PutRequest": {
                "Item": {
                  "Artist": {
                    "S": "No One You Know"
                  },
                  "SongTitle": {
                    "S": "Call Me Today"
                  },
                  "AlbumTitle": {
                    "S": "Somewhat Famous"
                  }
                }
              }
            },
            {
              "PutRequest": {
                "Item": {
                  "Artist": {
                    "S": "Acme Band"
                  },
                  "SongTitle": {
                    "S": "Happy Day"
                  },
                  "AlbumTitle": {
                    "S": "Songs About Life"
                  }
                }
              }
            },
            {
              "PutRequest": {
                "Item": {
                  "Artist": {
                    "S": "No One You Know"
                  },
                  "SongTitle": {
                    "S": "Scared of My Shadow"
                  },
                  "AlbumTitle": {
                    "S": "Blue Sky Blues"
                  }
                }
              }
            }
          ]
        },
        "output": [
          {
            "MusicCollection": [
              {
                "PutRequest": {
                  "Item": {
                    "Artist": {
                      "S": "No One You Know"
                    },
                    "SongTitle": {
                      "S": "Call Me Today"
                    },
                    "AlbumTitle": {
                      "S": "Somewhat Famous"
                    }
                  }
                }
              },
              {
                "PutRequest": {
                  "Item": {
                    "Artist": {
                      "S": "Acme Band"
                    },
                    "SongTitle": {
                      "S": "Happy Day"
                    },
                    "AlbumTitle": {
                      "S": "Songs About Life"
                    }
                  }
                }
              }
            ]
          },
          {
            "MusicCollection": [
              {
                "PutRequest": {
                  "Item": {
                    "Artist": {
                      "S": "No One You Know"
                    },
                    "SongTitle": {
                      "S": "Scared of My Shadow"
                    },
                    "AlbumTitle": {
                      "S": "Blue Sky Blues"
                    }
                  }
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 45704869
  },
  {
    "context": [
      "For this, why not use `jq` [JQ][1] utility for a one liner.",
      "You can achieve the:",
      "$ echo `jq \".pages\" /tmp/2.json`",
      "{ \"giga-10\": [ \"overview\" ] }"
    ],
    "utterance": "Select the value of the top-level 'pages' key from the file /tmp/2.json.",
    "expressions": [
      ".pages"
    ],
    "data": [
      {
        "input": {
          "pages": {
            "giga-10": [
              "overview"
            ]
          }
        },
        "output": {
          "giga-10": [
            "overview"
          ]
        }
      }
    ],
    "identifier": 45745684
  },
  {
    "context": [
      "I've got a tool that outputs a JSON record on each line, and I'd like to process it with `jq`.",
      "When I pass this to `jq` as follows:\n\n    ./tool | jq 'group_by(.id)'\n\n...it outputs an error:\n\n    jq: error (at <stdin>:1): Cannot index string with string \"id\"\n\nHow do I get `jq` to handle JSON-record-per-line data?",
      "**Use the `--slurp` (or `-s`) switch:**\n\n    ./tool | jq --slurp 'group_by(.id)'",
      "For example:\n\n    ./tool | jq -s 'group_by(.id) | map({id: .[0].id, count: length})'",
      "cat /tmp/json | jq -s '.id'\n> jq: error (at <stdin>:7): Cannot index array with string \"id\"",
      "cat /tmp/json | jq -s '.[].id'\n> 123\n> 456"
    ],
    "utterance": "Group line-delimited records by id and get an array with counts for each id value.",
    "expressions": [
      "jq -s 'group_by(.id)'",
      "jq -s 'group_by(.id) | map({id: .[0].id, count: length})'"
    ],
    "data": [
      {
        "input": [
          {
            "ts": "2017-08-15T21:20:47.029Z",
            "id": "123",
            "elapsed_ms": 10
          },
          {
            "ts": "2017-08-15T21:20:47.044Z",
            "id": "456",
            "elapsed_ms": 13
          }
        ],
        "output": [
          [
            {
              "ts": "2017-08-15T21:20:47.029Z",
              "id": "123",
              "elapsed_ms": 10
            }
          ],
          [
            {
              "ts": "2017-08-15T21:20:47.044Z",
              "id": "456",
              "elapsed_ms": 13
            }
          ]
        ]
      }
    ],
    "identifier": 45714384
  },
  {
    "context": [
      "I\u2019d like group them by two fields: repo and path. And then keep the two objects for each grouping with the most recent \"modified\" timestamp and delete all the other objects in the json file.",
      ".results |= [group_by({repo,path})[] | sort_by(.modified)[-2:][]]",
      "After grouping the items in the array by `repo` and `path`, you sort the groups by `modified` and keep the last two items of the sorted group. Then split the groups up again and collect them into a new array.",
      ".results |= [reduce .[] as $r ( {};\n                   .[$r.repo][$r.path] |= ((.+[$r]) | sort_by(.modified)[-2:])) \n                 | .[][]]"
    ],
    "utterance": "For each unique combination of repo and path, keep only the two objects with the most recent modified timestamps; remove all others.",
    "expressions": [
      ".results |= [group_by({repo,path})[] | sort_by(.modified)[-2:][]]",
      ".results |= [reduce .[] as $r ( {}; .[$r.repo][$r.path] |= ((.+[$r]) | sort_by(.modified)[-2:])) | .[][]]"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "repo": "repo1",
              "path": "docker_image_dynamic",
              "size": 3624,
              "modified": "2016-10-01T06:22:16.335Z"
            },
            {
              "repo": "repo1",
              "path": "docker_image_dynamic",
              "size": 3646,
              "modified": "2016-10-01T07:03:58.465Z"
            },
            {
              "repo": "repo1",
              "path": "docker_image_dynamic",
              "size": 3646,
              "modified": "2016-10-01T07:06:36.522Z"
            },
            {
              "repo": "repo2",
              "path": "docker_image_static",
              "size": 3624,
              "modified": "2016-09-29T20:31:44.054Z"
            }
          ]
        },
        "output": {
          "results": [
            {
              "repo": "repo1",
              "path": "docker_image_dynamic",
              "size": 3646,
              "modified": "2016-10-01T07:03:58.465Z"
            },
            {
              "repo": "repo1",
              "path": "docker_image_dynamic",
              "size": 3646,
              "modified": "2016-10-01T07:06:36.522Z"
            },
            {
              "repo": "repo2",
              "path": "docker_image_static",
              "size": 3624,
              "modified": "2016-09-29T20:31:44.054Z"
            }
          ]
        }
      }
    ],
    "identifier": 45705279
  },
  {
    "context": [
      "I would like to change the value of all the `k2` keys in the `some_array` array where the value of the `k1` key is \"B\".",
      "cat some.json | jq '.some_array = (.some_array | map(if .k1 == \"B\" then . + {\"k2\":\"changed\"} else . end))'",
      "Here's another solution.\n\n    jq '(.some_array[] | select(.k1 == \"B\") | .k2) |= \"new_value\"'\n\nOutput\n\n    {\n      \"some_array\": [\n        {\n          \"k1\": \"A\",\n          \"k2\": \"XXX\"\n        },\n        {\n          \"k1\": \"B\",\n          \"k2\": \"new_value\"\n        }\n      ]\n    }\n\n",
      ".some_array |= map(if .k1==\"B\" then .k2=\"changed\" else . end)"
    ],
    "utterance": "Update the value of k2 to a new value in all objects inside some_array where k1 is equal to B.",
    "expressions": [
      ".some_array |= map(if .k1==\"B\" then .k2=\"changed\" else . end)",
      ".some_array = (.some_array | map(if .k1 == \"B\" then . + {\"k2\":\"changed\"} else . end))",
      "(.some_array[] | select(.k1 == \"B\") | .k2) |= \"new_value\""
    ],
    "data": [
      {
        "input": {
          "some_array": [
            {
              "k1": "A",
              "k2": "XXX"
            },
            {
              "k1": "B",
              "k2": "YYY"
            }
          ]
        },
        "output": {
          "some_array": [
            {
              "k1": "A",
              "k2": "XXX"
            },
            {
              "k1": "B",
              "k2": "changed"
            }
          ]
        }
      }
    ],
    "identifier": 45747895
  },
  {
    "context": [
      "I just want to filter those out and get a JSON format that looks specifically like this.",
      "Is there a way to filter specific property key-values within arrays using jq?",
      "{catalog}\n| .catalog |= map( {name, catalog} )\n| .catalog[].catalog |= map( {name, uniqueId} )\n| .catalog |= .[0:1]",
      "walk(if type == \"object\" \n         then with_entries(select(.key == \"name\" or .key == \"uniqueId\" or .key == \"catalog\"))\n         else . end)"
    ],
    "utterance": "Return only the name and catalog properties at the top-level array objects, and only the name and uniqueId properties at the next nested catalog array level, removing all other fields.",
    "expressions": [
      "{catalog}\n| .catalog |= map( {name, catalog} )\n| .catalog[].catalog |= map( {name, uniqueId} )",
      "walk(if type == \"object\" \n         then with_entries(select(.key == \"name\" or .key == \"uniqueId\" or .key == \"catalog\"))\n         else . end)"
    ],
    "identifier": 45758631
  },
  {
    "context": [
      "I need to return all values in the specified JSON array based on an argument.",
      "jq --arg appenv \"$APPLICATION_ENVIRONMENT\" '.environments[\"$env[]\"]' test-app-1.json",
      "use variable name consistently: if you define appenv, use $appenv, not $env",
      "address with .environments[$appenv]",
      ".environments[$appenv][]"
    ],
    "utterance": "Return all servers for the environment specified by a variable, e.g., if the environment is development, output all its server values.",
    "expressions": [
      ".environments[$appenv][]"
    ],
    "data": [
      {
        "input": {
          "application.name": "test-app-1",
          "environments": {
            "development": [
              "server1"
            ],
            "stage": [
              "server2",
              "server3"
            ],
            "production": [
              "server4",
              "server5"
            ]
          }
        },
        "output": "server1"
      }
    ],
    "identifier": 45784813
  },
  {
    "context": [
      "I have this:\r\n\r\n    jq -r '.letters[0].secondary_letters[0] | \"\\(.name)\"' letters.json\r\n\r\nwhich outputs:\r\n\r\n    a\r\n    aa\r\n\r\nI'd like them to be: a, aa",
      "The json looks like:\r\n\r\n      \"secondary_letters\": [\r\n        {\r\n          \"id\": 1,\r\n          \"name\": \"a\"\r\n        },\r\n        {\r\n          \"id\": 2,\r\n          \"name\": \"aa\"\r\n        }\r\n\r\nThere might be more so the jq command should be able to extract as many as sub nodes needed.",
      "jq -r '.secondary_letters | map(.name) | join(\", \")'",
      "jq -r '[.secondary_letters[].name] | join(\", \")' letters.json"
    ],
    "utterance": "List the values of all secondary_letters[].name fields separated by a comma and a space, regardless of the number of elements.",
    "expressions": [
      ".secondary_letters | map(.name) | join(\", \")",
      "[.secondary_letters[].name] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "secondary_letters": [
            {
              "id": 1,
              "name": "a"
            },
            {
              "id": 2,
              "name": "aa"
            }
          ]
        },
        "output": "a, aa"
      }
    ],
    "identifier": 45786861
  },
  {
    "context": [
      "I'd like to remove any objects from the first file where the name and surname fields match an object of the second file, so that the results should look like this:",
      "map(select(any(.; contains($arg[]))==false))",
      "jq -M --argfile arg second.json 'map(select(any(.; contains($arg[]))==false))' data.json",
      "jq --slurpfile s f2.json '[ .[] | . as $o | if (reduce $s[0][] as $i ([]; . + [($o | contains($i))]) | any) then empty else $o end ]' f1.json"
    ],
    "utterance": "Remove objects from the first input where both 'name' and 'surname' match any object in the second input.",
    "expressions": [
      "map(select(any(.; contains($arg[]))==false))",
      "map(select(all($arg[]; (.name != .name or .surname != .surname))))",
      "[ .[] | . as $o | if (reduce $s[0][] as $i ([]; . + [($o | contains($i))]) | any) then empty else $o end ]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "Cynthia",
              "surname": "Craig",
              "isActive": true,
              "balance": "$2,426.88"
            },
            {
              "name": "Elise",
              "surname": "Long",
              "isActive": false,
              "balance": "$1,892.72"
            },
            {
              "name": "Hyde",
              "surname": "Adkins",
              "isActive": true,
              "balance": "$1,769.34"
            },
            {
              "name": "Matthews",
              "surname": "Jefferson",
              "isActive": true,
              "balance": "$1,991.42"
            },
            {
              "name": "Kris",
              "surname": "Norris",
              "isActive": false,
              "balance": "$2,137.11"
            }
          ],
          [
            {
              "name": "Cynthia",
              "surname": "Craig"
            },
            {
              "name": "Kris",
              "surname": "Norris"
            }
          ]
        ],
        "output": [
          {
            "name": "Elise",
            "surname": "Long",
            "isActive": false,
            "balance": "$1,892.72"
          },
          {
            "name": "Hyde",
            "surname": "Adkins",
            "isActive": true,
            "balance": "$1,769.34"
          },
          {
            "name": "Matthews",
            "surname": "Jefferson",
            "isActive": true,
            "balance": "$1,991.42"
          }
        ]
      }
    ],
    "identifier": 45726428
  },
  {
    "context": [
      "**Input Json:**",
      "**Desired Format:**",
      "jq ['.[] | { name: .name, steps: .elements[].steps[]} | {name:.name, stepName:.steps.name, status:.steps.result.status}']",
      "With the above command, I am getting the following format:",
      "Here is a solution:",
      ".[]\n| .Result = [\n      .elements[]\n    | .steps[]\n    | {stepName:.name, status:.result.status}\n  ]\n| del(.elements)",
      "This is just a minor variation on jq170727's answer.",
      "The last step builds the object out of the parts you want rather than deleting the ones you don't want.",
      "jq '.[]\n| .Result =\n  [  \n     .elements[]\n     | .steps[]\n     | { stepName:.name, status:.result.status }\n  ]\n| { name, Result }'"
    ],
    "utterance": "Transform the nested structure so that each top-level object has its name and a Result array with stepName and status for each step.",
    "expressions": [
      ".[] | .Result = [.elements[] | .steps[] | {stepName:.name, status:.result.status}] | del(.elements)",
      ".[] | .Result = [.elements[] | .steps[] | {stepName:.name, status:.result.status}] | { name, Result }"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Successful retrieval",
            "elements": [
              {
                "scenario": "First",
                "steps": [
                  {
                    "name": "as a customer",
                    "result": {
                      "status": "passed",
                      "duration": 29428
                    }
                  },
                  {
                    "name": "I hit API",
                    "result": {
                      "status": "passed",
                      "duration": 210403731
                    }
                  },
                  {
                    "name": "API should respond",
                    "result": {
                      "status": "passed",
                      "duration": 1246183
                    }
                  }
                ]
              }
            ]
          }
        ],
        "output": {
          "name": "Successful retrieval",
          "Result": [
            {
              "stepName": "as a customer",
              "status": "passed"
            },
            {
              "stepName": "I hit API",
              "status": "passed"
            },
            {
              "stepName": "API should respond",
              "status": "passed"
            }
          ]
        }
      }
    ],
    "identifier": 45765147
  },
  {
    "context": [
      "How can I get the values of \"field-2\", \"field-three\" or \"field-three.url\" for element under `content.book1` (using `jq` at least)?",
      "to handle keys with non-identifier characters like `-` you can use double quotes.",
      "cat /tmp/my.data.json | jq '.content.book1.\"field-2\"'",
      "cat /tmp/my.data.json | jq '.content.book1.\"field-three\"'",
      "cat /tmp/my.data.json | jq '.content.book1.\"field-three\".url'",
      "If in doubt, use the pipe explicitly.",
      "for key names with special characters such as \"-\", one cannot use the simplified \".keyname\" syntax. There are several alternatives, but the most robust is simply to use the form `.[\"KEY NAME\"]`",
      "$ cat /tmp/my.data.json| jq \".content.book1.\\\"field-2\\\"\"",
      "$ cat /tmp/my.data.json| jq \".content.book1.\\\"field-three\\\".\\\"url\\\"\""
    ],
    "utterance": "Retrieve the values of the keys 'field-2', 'field-three', and the subkey 'url' of 'field-three' under 'content.book1' when the keys contain dashes.",
    "expressions": [
      ".content.book1[\"field-2\"]",
      ".content.book1[\"field-three\"]",
      ".content.book1[\"field-three\"][\"url\"]",
      ".content.book1.\"field-2\"",
      ".content.book1.\"field-three\"",
      ".content.book1.\"field-three\".url"
    ],
    "data": [
      {
        "input": {
          "pages": {
            "book1": [
              "page1",
              "page2-para1",
              "page3-para1-sentence1",
              "page3-para2-sentence3-word4"
            ]
          },
          "content": {
            "book1": {
              "name": "giga",
              "url": "-",
              "field1": "value1",
              "field-2": "value-2",
              "field-three": {
                "name": "THIRD",
                "url": "book1/field-three/",
                "short-url": "book1/field-three/chota-chetan"
              },
              "authur": {
                "name": "lori CHUCK",
                "displayIndex": 4
              },
              "route": "/in-gc/hindi-chini-bhai-bhai"
            }
          }
        },
        "output": "value-2"
      },
      {
        "input": {
          "pages": {
            "book1": [
              "page1",
              "page2-para1",
              "page3-para1-sentence1",
              "page3-para2-sentence3-word4"
            ]
          },
          "content": {
            "book1": {
              "name": "giga",
              "url": "-",
              "field1": "value1",
              "field-2": "value-2",
              "field-three": {
                "name": "THIRD",
                "url": "book1/field-three/",
                "short-url": "book1/field-three/chota-chetan"
              },
              "authur": {
                "name": "lori CHUCK",
                "displayIndex": 4
              },
              "route": "/in-gc/hindi-chini-bhai-bhai"
            }
          }
        },
        "output": {
          "name": "THIRD",
          "url": "book1/field-three/",
          "short-url": "book1/field-three/chota-chetan"
        }
      },
      {
        "input": {
          "pages": {
            "book1": [
              "page1",
              "page2-para1",
              "page3-para1-sentence1",
              "page3-para2-sentence3-word4"
            ]
          },
          "content": {
            "book1": {
              "name": "giga",
              "url": "-",
              "field1": "value1",
              "field-2": "value-2",
              "field-three": {
                "name": "THIRD",
                "url": "book1/field-three/",
                "short-url": "book1/field-three/chota-chetan"
              },
              "authur": {
                "name": "lori CHUCK",
                "displayIndex": 4
              },
              "route": "/in-gc/hindi-chini-bhai-bhai"
            }
          }
        },
        "output": "book1/field-three/"
      }
    ],
    "identifier": 45703291
  },
  {
    "context": [
      "Here\u2019s my example JSON that I\u2019m trying to replicate programmatically:",
      "{\r\n  \"title\": \"New Story\",\r\n  \"channels\": [\r\n    {\r\n      \"id\": \"65tyc2TLUZsO\"\r\n    }\r\n  ],\r\n  \"description\": \"Story Description Here\",\r\n  \"new_files\": [\r\n    {\r\n      \"filename\": \"419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx\",\r\n      \"description\": \"File Description ABC\"\r\n    },\r\n    {\r\n    \"filename\": \"5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf\",\r\n    \"description\":\"File Description XYZ\"\r\n    }\r\n  ]\r\n}",
      "To reassemble that object stream into your original json you can use a function like\r\n\r\n    def unflatten:\r\n          group_by(.title)\r\n        | .[]\r\n        | {\r\n              title:       .[0].title\r\n            , description: .[0].story\r\n          }\r\n          + { channels:    map(.id) | unique | map({id:.}) }\r\n          + { new_files:   map({filename, description}) | unique }\r\n    ;\r\n\r\nby combining the filters\r\n\r\n      [ readcsv ]\r\n    | unflatten",
      "Here is a solution which, for clarity, involves two invocations of jq:\n\n     jq -R 'split(\",\")' input.csv | jq -f program.jq\n\n(These two calls could easily be rendered into one as explained below.)",
      "Here then is program.jq:\n\n    # Input: an array of \"filename, description\" pairs\n    # Output: an array of {filename: _, description: _} objects\n    def new_files:\n      if length == 0 then []\n      else [{filename: .[0], description: .[1]}] + (.[2:] | new_files)\n      end;\n       \n    inputs\n    | {title: .[0], channels: [{id: .[1]}], description: .[2] } \n    + {new_files: (.[3:] | new_files) }",
      "One way to avoid invoking jq twice would be to invoke jq with the -R and -s options, using the above definition of `new_files` and the following program:\n\n    split(\"\\n\")\n    | map(split(\",\"))\n    | .[1:][]\n    | {title: .[0], channels: [{id: .[1]}], description: .[2] } \n    + {new_files: (.[3:] | new_files) }"
    ],
    "utterance": "Convert rows where the first fields are title, channel id, and description, and remaining fields are alternating filenames and file descriptions, into an object with those top-level fields, channels array with id, and new_files array with filename/description pairs.",
    "expressions": [
      "def new_files:\n  if length == 0 then []\n  else [{filename: .[0], description: .[1]}] + (.[2:] | new_files)\n  end;\n   \ninputs\n| {title: .[0], channels: [{id: .[1]}], description: .[2] } \n+ {new_files: (.[3:] | new_files) }",
      "split(\"\\n\")\n| map(split(\",\"))\n| .[1:][]\n| {title: .[0], channels: [{id: .[1]}], description: .[2] } \n+ {new_files: (.[3:] | new_files) }"
    ],
    "data": [
      {
        "input": [
          "title,id,description,filename1,filedesc1,filename2,filedesc2",
          "New Story,65tyc2TLUZsO,Story Description Here,419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx,File Description ABC,5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf,File Description XYZ"
        ],
        "output": {
          "title": "New Story",
          "channels": [
            {
              "id": "65tyc2TLUZsO"
            }
          ],
          "description": "Story Description Here",
          "new_files": [
            {
              "filename": "419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx",
              "description": "File Description ABC"
            },
            {
              "filename": "5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf",
              "description": "File Description XYZ"
            }
          ]
        }
      }
    ],
    "identifier": 45698434
  },
  {
    "context": [
      "Following represents a sample json file:\r\n\r\n    [\r\n      {\r\n        \"jou_entry\": {\r\n          \"id\": 655002886,\r\n          \"units\": 2\r\n        }\r\n      },\r\n      {\r\n        \"jou_entry\": {\r\n          \"id\": 655002823,\r\n          \"units\": 4\r\n        }\r\n      },\r\n      {\r\n        \"jou_entry\": {\r\n          \"id\": 657553949,\r\n          \"units\": 6\r\n        }\r\n      }\r\n    ]",
      "Where as the proposed solution requires the json in the following format:\r\n\r\n    [\r\n      {\r\n        \"id\": 655002886,\r\n        \"units\": 2\r\n      },\r\n      {\r\n        \"id\": 655002823,\r\n        \"units\": 4\r\n      },\r\n      {\r\n        \"id\": 657553949,\r\n        \"units\": 6\r\n      }\r\n    ]",
      "I am able to convert the json from source format to required format using the following jq filter\r\n\r\n    jq -r '[.[] | .\"jou_entry\"]' \r\n\r\nBut I don't like the hard-coding of key \"jou_entry\" in the filter. As this will require individual key definition for so many files. I would like to have the conversion without the hard-coded value.",
      "This gets the desired output\r\n\r\n    jq '[.[] | .[]]'"
    ],
    "utterance": "Flatten an array of single-key objects by extracting their values into a new array, regardless of the specific key name.",
    "expressions": [
      "[.[] | .[]]"
    ],
    "data": [
      {
        "input": [
          {
            "jou_entry": {
              "id": 655002886,
              "units": 2
            }
          },
          {
            "jou_entry": {
              "id": 655002823,
              "units": 4
            }
          },
          {
            "jou_entry": {
              "id": 657553949,
              "units": 6
            }
          }
        ],
        "output": [
          {
            "id": 655002886,
            "units": 2
          },
          {
            "id": 655002823,
            "units": 4
          },
          {
            "id": 657553949,
            "units": 6
          }
        ]
      }
    ],
    "identifier": 45827932
  },
  {
    "context": [
      "How can I select the property `NodeLaunchConfig123456789` using `jq` and a regex like `NodeLaunchConfig\\w+`?",
      "{ Resources: .Resources | with_entries(select(.key|match(\"NodeLaunchConfig[a-zA-Z0-9_]+\"))) }",
      ".Resources |= with_entries(select(.key|match(\"NodeLaunchConfig[a-zA-Z0-9_]+\")))"
    ],
    "utterance": "Select all properties under 'Resources' whose key matches the regex 'NodeLaunchConfig\\w+'.",
    "expressions": [
      "{ Resources: .Resources | with_entries(select(.key|match(\"NodeLaunchConfig[a-zA-Z0-9_]+\"))) }",
      ".Resources |= with_entries(select(.key|match(\"NodeLaunchConfig[a-zA-Z0-9_]+\")))"
    ],
    "data": [
      {
        "input": {
          "Resources": {
            "NodeLaunchConfig123456789": {
              "...": "..."
            }
          }
        },
        "output": {
          "Resources": {
            "NodeLaunchConfig123456789": {
              "...": "..."
            }
          }
        }
      }
    ],
    "identifier": 45924263
  },
  {
    "context": [
      "How can i with jq command get new updated **whole** file, not just only part of it?",
      "You can map to **array** and resign the `int` by operation, like:",
      "jq --arg mod \"GOOD\" '.[] | .int=.int + {stat: $mod}' tmp.json",
      "If you put your data in `data.json` and the changes you want to make to\neach record into a separate `arg.json` argument file like\n\n    {\n        \"1234\": { \"int\": { \"stat\": \"GOOD\" } },\n        \"4321\": { \"int\": { \"stat\": \"BAD\", \"xxx\": \"yyy\" } }\n    }",
      "$ jq -M --argfile arg arg.json 'map(. * $arg[._id])' data.json"
    ],
    "utterance": "Update every object's 'int' field by adding or setting a 'stat' field to a specific value, while outputting the entire updated array.",
    "expressions": [
      "map(.int = .int + {stat: $mod})",
      "map(.int = .int + {stat: \"GOOD\"})",
      "map(. * $arg[._id])"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "1234",
            "org": "org1",
            "int": {
              "url": "http://url.com.uk:1234"
            }
          },
          {
            "_id": "4321",
            "org": "org2",
            "int": {
              "url": "http://url.com.us:4321"
            }
          }
        ],
        "output": [
          {
            "_id": "1234",
            "org": "org1",
            "int": {
              "url": "http://url.com.uk:1234",
              "stat": "GOOD"
            }
          },
          {
            "_id": "4321",
            "org": "org2",
            "int": {
              "url": "http://url.com.us:4321",
              "stat": "GOOD"
            }
          }
        ]
      }
    ],
    "identifier": 45829791
  },
  {
    "context": [
      "1. Environment Tag value is not one of (prod, stg, test, dev)",
      "aws ec2 describe-instances --output json --query 'Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}' | jq '.[]' | jq 'select(.EnvTag[] | contains (\"prod\", \"dev\") | not)'",
      "I believe I've found a solution.  It may not be optimal, but I've found a way to pipe-chain excludes of exact strings:",
      "aws ec2 describe-instances --output json --query 'Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}' | jq '.[]' | jq 'select(.EnvTag[] != \"dev\") | select (.EnvTag[] != \"stg\") | select (.EnvTag[] != \"prod\") | select (.EnvTag[] != \"test\") | select (.EnvTag[] != \"ops\") | .ID'",
      "It can be greatly simplified. First, in this case, there is no need to invoke jq twice. `jq '.[]' | jq ...` is equivalent to `jq '.[] | ...'`",
      "Second, the long pipeline of 'select' filters can be condensed, for example to:\n\n    select(.EnvTag[]\n      | (. != \"dev\" and . != \"stg\" and . != \"prod\" and . != \"test\" and . != \"ops\"))",
      "or, if your jq has `all/2`, even more concisely to:\n\n    select( . as $in | all( (\"dev\", \"stg\", \"prod\", \"test\", \"ops\"); . != $in.EnvTag[]) )"
    ],
    "utterance": "List the instance IDs whose Environment tag exists but is not exactly 'prod', 'stg', 'test', 'dev', or 'ops'.",
    "expressions": [
      ".[] | select(.EnvTag[] | (. != \"dev\" and . != \"stg\" and . != \"prod\" and . != \"test\" and . != \"ops\")) | .ID",
      ".[] | select(. as $in | all([\"dev\", \"stg\", \"prod\", \"test\", \"ops\"]; . != $in.EnvTag[])) | .ID"
    ],
    "data": [
      {
        "input": [
          {
            "EnvTag": [
              "stg"
            ],
            "ID": "i-87654321",
            "FinTag": [
              "GroupA"
            ]
          },
          {
            "EnvTag": [
              "oops"
            ],
            "ID": "i-99999999",
            "FinTag": [
              "GroupA"
            ]
          }
        ],
        "output": [
          "i-99999999"
        ]
      }
    ],
    "identifier": 45804706
  },
  {
    "context": [
      "I have this file:\n\n    [\n        \"smoke-tests\",\n        \"push-apps-manager\"\n    ]\n\nI'd like to get this output using JQ:\n\n    {\n      \"errands\": [\n        {\"name\": \"smoke-tests\", \"post_deploy\": true},\n        {\"name\": \"push-apps-manager\", \"post_deploy\": true}\n      ]\n    }",
      "% jq '{errands: [.[] | {name: ., post_deploy: true}]}' names.json",
      "You can also use the `map` function (which I rarely remember how to use correctly, but it turns out is pretty simple here):\n\n    % jq '{errands: map({name:., post_deploy: true})}' names.json",
      "{ \"errands\": [ { \"name\": .[], \"post_deploy\": true } ] }"
    ],
    "utterance": "Transform an array of strings into an object with a key 'errands', whose value is an array of objects each having 'name' as the string and 'post_deploy' as true.",
    "expressions": [
      "{errands: [.[] | {name: ., post_deploy: true}]}",
      "{errands: map({name:., post_deploy: true})}",
      "{ \"errands\": [ { \"name\": .[], \"post_deploy\": true } ] }"
    ],
    "data": [
      {
        "input": [
          "smoke-tests",
          "push-apps-manager"
        ],
        "output": {
          "errands": [
            {
              "name": "smoke-tests",
              "post_deploy": true
            },
            {
              "name": "push-apps-manager",
              "post_deploy": true
            }
          ]
        }
      }
    ],
    "identifier": 45850452
  },
  {
    "context": [
      "The problem is that the number an name of the networks varies.",
      "I want my final solution to not mention the network names in the filter but have them in the output.",
      "How do I access the parent key name as a label with outputting child details?",
      "Here is a more general solution which uses **reduce** and **keys** to construct the Networks object",
      ".[]\n  | {\n       Name: .Name,\n       Id:   .Id,\n       Path: .Path,\n       Networks: (\n            .NetworkSettings.Networks as $n\n          | reduce ($n|keys[]) as $k (\n               {}\n             ; .[$k] = ( $n[$k] | {IPAddress, NetworkID} )\n            )\n       )\n     }",
      "Which can be simplified a little bit using `|=` to update Networks instead of constructing a new object",
      ".[]\n  | {\n       Name: .Name,\n       Id:   .Id,\n       Path: .Path,\n       Networks: (\n            .NetworkSettings.Networks\n          | reduce keys[] as $k (\n               .\n             ; .[$k] |= {IPAddress, NetworkID}\n            )\n       )\n     }"
    ],
    "utterance": "Output container Name, Id, Path, and for each network present show network name as key with its IPAddress and NetworkID.",
    "expressions": [
      ".[] | { Name: .Name, Id: .Id, Path: .Path, Networks: ( .NetworkSettings.Networks as $n | reduce ($n|keys[]) as $k ({}; .[$k] = ( $n[$k] | {IPAddress, NetworkID} ) ) ) }",
      ".[] | { Name: .Name, Id: .Id, Path: .Path, Networks: ( .NetworkSettings.Networks | reduce keys[] as $k (. ; .[$k] |= {IPAddress, NetworkID} ) ) }"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a",
            "Created": "2017-08-08T14:17:47.911028584Z",
            "Path": "nginx",
            "Args": [
              "-g",
              "daemon off;"
            ],
            "State": {
              "Status": "running",
              "Running": true,
              "Paused": false,
              "Restarting": false,
              "OOMKilled": false,
              "Dead": false,
              "Pid": 18628,
              "ExitCode": 0,
              "Error": "",
              "StartedAt": "2017-08-08T14:17:48.299360684Z",
              "FinishedAt": "0001-01-01T00:00:00Z"
            },
            "Image": "sha256:b8efb18f159bd948486f18bd8940b56fd2298b438229f5bd2bcf4cedcf037448",
            "ResolvConfPath": "/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/resolv.conf",
            "HostnamePath": "/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/hostname",
            "HostsPath": "/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/hosts",
            "LogPath": "/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a-json.log",
            "Name": "/nginx.1.attiwcma8h39wclpsncp608tk",
            "RestartCount": 0,
            "Driver": "overlay",
            "MountLabel": "",
            "ProcessLabel": "",
            "AppArmorProfile": "",
            "ExecIDs": null,
            "HostConfig": {},
            "GraphDriver": {},
            "Mounts": [],
            "Config": {},
            "NetworkSettings": {
              "Bridge": "",
              "SandboxID": "66e098ef6e1bea3b2f66dcc7460eab9fc23436cb39836918a46e1d38692a55cb",
              "HairpinMode": false,
              "LinkLocalIPv6Address": "",
              "LinkLocalIPv6PrefixLen": 0,
              "Ports": {
                "80/tcp": null
              },
              "SandboxKey": "/var/run/docker/netns/66e098ef6e1b",
              "SecondaryIPAddresses": null,
              "SecondaryIPv6Addresses": null,
              "EndpointID": "",
              "Gateway": "",
              "GlobalIPv6Address": "",
              "GlobalIPv6PrefixLen": 0,
              "IPAddress": "",
              "IPPrefixLen": 0,
              "IPv6Gateway": "",
              "MacAddress": "",
              "Networks": {
                "ingress": {
                  "IPAMConfig": {
                    "IPv4Address": "10.255.0.5"
                  },
                  "Links": null,
                  "Aliases": [
                    "f2ee9caae862"
                  ],
                  "NetworkID": "zznyce2va5pfggq14su51zygn",
                  "EndpointID": "09b287a8d82e85d0790a8ea8634e97844481cb478ded89f6ac1dfda7e3c31f76",
                  "Gateway": "",
                  "IPAddress": "10.255.0.5",
                  "IPPrefixLen": 16,
                  "IPv6Gateway": "",
                  "GlobalIPv6Address": "",
                  "GlobalIPv6PrefixLen": 0,
                  "MacAddress": "02:42:0a:ff:00:05",
                  "DriverOpts": null
                },
                "webnet": {
                  "IPAMConfig": {
                    "IPv4Address": "10.0.0.3"
                  },
                  "Links": null,
                  "Aliases": [
                    "f2ee9caae862"
                  ],
                  "NetworkID": "g66ea3npnaiwvvdy66rijt5yo",
                  "EndpointID": "46b7ef9ba2d82cf56f34ade3a80a094b5f92f05d5e9051dab0542e2992298bb2",
                  "Gateway": "",
                  "IPAddress": "10.0.0.3",
                  "IPPrefixLen": 24,
                  "IPv6Gateway": "",
                  "GlobalIPv6Address": "",
                  "GlobalIPv6PrefixLen": 0,
                  "MacAddress": "02:42:0a:00:00:03",
                  "DriverOpts": null
                }
              }
            }
          }
        ],
        "output": {
          "Name": "/nginx.1.attiwcma8h39wclpsncp608tk",
          "Id": "f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a",
          "Path": "nginx",
          "Networks": {
            "ingress": {
              "IPAddress": "10.255.0.5",
              "NetworkID": "zznyce2va5pfggq14su51zygn"
            },
            "webnet": {
              "IPAddress": "10.0.0.3",
              "NetworkID": "g66ea3npnaiwvvdy66rijt5yo"
            }
          }
        }
      }
    ],
    "identifier": 45574029
  },
  {
    "context": [
      "How can i find the first and the last entry of those arrays with jq? I tried the function min/maxby but that function only delivers the entrys with the first and last in charakter of the Alphabet.",
      "[0] returns the first element in an array; [-1] returns the last. (See the \"basic filters\" section of the manual.)",
      "For the input given above\n    jq '.[][][][0, -1]'",
      "Here is a solution using [first](https://stedolan.github.io/jq/manual/#first,last,nth(n)) and [last](https://stedolan.github.io/jq/manual/#first,last,nth(n))\n\n    .cruises[].waypoint_cities | first, last",
      "first: data.cruises[0].waypoint_cities[0]\n- last: data.cruises[0].waypoint_cities[data.cruises[0].waypoint_cities.length-1]"
    ],
    "utterance": "Extract the first and last element from the waypoint_cities array in each cruise entry.",
    "expressions": [
      ".cruises[].waypoint_cities | first, last",
      ".cruises[].waypoint_cities[0, -1]"
    ],
    "data": [
      {
        "input": {
          "cruises": [
            {
              "waypoint_cities": [
                "Palma de Mallorca",
                "C\u00e1diz",
                "Puerto del Rosario, Fuerteventura",
                "Arrecife, Lanzarote",
                "Arrecife, Lanzarote",
                "Agadir",
                "Gibraltar",
                "Barcelona",
                "Palma de Mallorca"
              ]
            }
          ]
        },
        "output": [
          "Palma de Mallorca",
          "Palma de Mallorca"
        ]
      }
    ],
    "identifier": 45979477
  },
  {
    "context": [
      "How to combine all these requirements into a single command line script which do all the following:\n\n  1. Iterate over all Kibana objects \n  2. Sorts the field order in each JSON object\n  3. Sort the embedded JSON text inside \"_source.fields\"",
      "You could define a function that would take an object and recreate it with sorted keys. Then apply it to objects you want sorted. Then apply this recursively on all objects in your tree.",
      "def sort_object: (objects | . as $in | reduce keys[] as $k ({}; .[$k] = $in[$k])) // .;\ndef sort_object_recursive: walk((objects | sort_object) // .);\n._source.fields |= (fromjson | sort_by(.name)) | sort_object_recursive | ._source.fields |= tojson"
    ],
    "utterance": "Sort all object keys recursively and also sort the array of objects embedded as a JSON string in the _source.fields field by the name property in each object.",
    "expressions": [
      "def sort_object: (objects | . as $in | reduce keys[] as $k ({}; .[$k] = $in[$k])) // .;\ndef sort_object_recursive: walk((objects | sort_object) // .);\n._source.fields |= (fromjson | sort_by(.name)) | sort_object_recursive | ._source.fields |= tojson"
    ],
    "data": [
      {
        "input": {
          "_id": "eslogs-*",
          "_index": ".kibana",
          "_source": {
            "fields": "[{\"name\":\"total_shards\",\"type\":\"number\",\"count\":0,\"scripted\":false,\"indexed\":true,\"analyzed\":false,\"doc_values\":true,\"searchable\":false,\"aggregatable\":false},{\"name\":\"took_millis\",\"type\":\"number\",\"count\":0,\"scripted\":false,\"indexed\":true,\"analyzed\":false,\"doc_values\":true,\"searchable\":false,\"aggregatable\":false},{\"name\":\"source\",\"type\":\"string\",\"count\":0,\"scripted\":false,\"indexed\":true,\"analyzed\":true,\"doc_values\":false,\"searchable\":true,\"aggregatable\":false}]",
            "notExpandable": true,
            "timeFieldName": "@timestamp",
            "title": "eslogs-*"
          },
          "_type": "index-pattern",
          "_version": 1,
          "found": true
        },
        "output": {
          "_id": "eslogs-*",
          "_index": ".kibana",
          "_source": {
            "fields": "[{\"aggregatable\":false,\"analyzed\":true,\"count\":0,\"doc_values\":false,\"indexed\":true,\"name\":\"source\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"took_millis\",\"scripted\":false,\"searchable\":false,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"total_shards\",\"scripted\":false,\"searchable\":false,\"type\":\"number\"}]",
            "notExpandable": true,
            "timeFieldName": "@timestamp",
            "title": "eslogs-*"
          },
          "_type": "index-pattern",
          "_version": 1,
          "found": true
        }
      }
    ],
    "identifier": 45823120
  },
  {
    "context": [
      "First I want to select an array by a property name. And then I want to select an object of the array by the value of the property `InstanceType`.",
      "Example for the property `zk_kafka` and the value `t2.medium`:\n\n    {\n      \"InstanceType\": \"t2.medium\",\n      \"zkMemory\": \"16\",\n      \"kafkaMemory\": \"8\"\n    }",
      "But I do not know how to filter the array of object by a property value.",
      "Use the `select` filter of `jq`:\n\n    jq '.zk_kafka | .[] | select(.InstanceType == \"t2.medium\")'",
      "jq --arg instance \"t2.medium\" '.zk_kafka | .[] | select(.InstanceType == $instance)'",
      "Alternatively, you can also use `map()`:\n\n    jq '.zk_kafka | map(select(.InstanceType == \"t2.medium\"))' input.json"
    ],
    "utterance": "Select the object from the array at key zk_kafka where InstanceType equals t2.medium.",
    "expressions": [
      ".zk_kafka | .[] | select(.InstanceType == \"t2.medium\")",
      ".zk_kafka | map(select(.InstanceType == \"t2.medium\"))",
      ".zk_kafka | .[] | select(.InstanceType == $instance)"
    ],
    "data": [
      {
        "input": {
          "zk_kafka": [
            {
              "InstanceType": "t2.medium",
              "zkMemory": "16",
              "kafkaMemory": "8"
            },
            {
              "InstanceType": "t2.small",
              "zkMemory": "8",
              "kafkaMemory": "4"
            }
          ],
          "es_hdfs": [
            {
              "InstanceType": "t2.medium",
              "esMemory": "16",
              "hdfsMemory": "8"
            },
            {
              "InstanceType": "t2.small",
              "esMemory": "8",
              "hdfsMemory": "4"
            }
          ]
        },
        "output": {
          "InstanceType": "t2.medium",
          "zkMemory": "16",
          "kafkaMemory": "8"
        }
      }
    ],
    "identifier": 46070012
  },
  {
    "context": [
      "jq is designed to work with json data. Your input is **not** pure json.",
      "If these assumptions hold true, you could probably use something like this:",
      "$ jq -R 'split(\"|\") | {request:.[5]|fromjson,response:.[6]|fromjson}' input.psv",
      "will produce just the json fragment from column 5:",
      "$ jq -M -Rc './\"|\" | .[5] | fromjson' data",
      "This filter",
      "$ jq -M -Rc './\"|\" | (.[5]|fromjson) + (.[6]|fromjson)' data",
      "will combine the objects in columns 5 and 6 into one object:"
    ],
    "utterance": "Extract and merge the JSON objects from the sixth and seventh pipe-separated columns in each line, discarding any text outside these JSON fragments.",
    "expressions": [
      "split(\"|\") | {request:.[5]|fromjson, response:.[6]|fromjson}",
      "split(\"|\") | (.[5]|fromjson) + (.[6]|fromjson)"
    ],
    "data": [
      {
        "input": "Sep  1 15:52:26 | IdentityValidationApi |  |  |  | {\"header\":{\"tenantId\":\"X03LHWE3\"}, \"serverTime\":\"2017-09-01T19:52:24.641Z\"} | {\"responseHeader\":{\"tenantID\": \"...\", \"fieldValue\":\"Engineer\"}} | D2C CrossCore Request-Response | IdentityValidationApi.corp-dev.com | /api/Inquiry | 172.30.68.88 |  | True",
        "output": {
          "header": {
            "tenantId": "X03LHWE3"
          },
          "serverTime": "2017-09-01T19:52:24.641Z",
          "responseHeader": {
            "tenantID": "...",
            "fieldValue": "Engineer"
          }
        }
      }
    ],
    "identifier": 46100997
  },
  {
    "context": [
      "I would like to write a `jq` program which returns `access_check.settings_tray.block.settings_tray_form` for the input `access_check`.",
      "you want a service name, if it contains a given tag name.",
      ".services | to_entries[] | select(any(.value.tags[].name; . == $name)).key",
      ".services | keys[] as $k | .[$k] | select(.tags[]?.name == $name) | $k"
    ],
    "utterance": "Return service names whose tags array contains an object with name equal to access_check.",
    "expressions": [
      ".services | to_entries[] | select(any(.value.tags[].name; . == $name)).key",
      ".services | keys[] as $k | .[$k] | select(.tags[]?.name == $name) | $k"
    ],
    "data": [
      {
        "input": {
          "services": {
            "main_content_renderer.off_canvas": {
              "class": "Drupal\\settings_tray\\Render\\MainContent\\OffCanvasRenderer",
              "arguments": [
                "@title_resolver",
                "@renderer"
              ],
              "tags": [
                {
                  "name": "render.main_content_renderer",
                  "format": "drupal_dialog.off_canvas"
                }
              ]
            },
            "access_check.settings_tray.block.settings_tray_form": {
              "class": "Drupal\\settings_tray\\Access\\BlockPluginHasSettingsTrayFormAccessCheck",
              "tags": [
                {
                  "name": "access_check",
                  "applies_to": "_access_block_plugin_has_settings_tray_form"
                }
              ]
            }
          }
        },
        "output": "access_check.settings_tray.block.settings_tray_form"
      }
    ],
    "identifier": 46159110
  },
  {
    "context": [
      "And print:\r\n\r\n    112 234324\r\n",
      "I get the values I want but they are printed on separate lines:\r\n\r\n    $ echo '{ \"fmep\": { \"foo\": 112, \"bar\": 234324, \"cat\": 21343423 } }' | jq '.fmep|.foo,.bar'\r\n    \r\n    112  \r\n    234324",
      "use [String Interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)) along with the `-r` option. e.g.\r\n\r\n    echo '{ \"fmep\": { \"foo\": 112, \"bar\": 234324, \"cat\": 21343423 } }' | \\\r\n    jq -r '.fmep| \"\\(.foo) \\(.bar)\"'\r\n\r\nproduces\r\n\r\n    112 234324",
      "You may also want to consider putting the values in an array and using [@tsv](https://jqlang.github.io/jq/manual/#Builtinoperatorsandfunctions:~:text=escaped%20by%20repetition.-,%40tsv,-%3A) e.g.\r\n\r\n    echo '{ \"fmep\": { \"foo\": 112, \"bar\": 234324, \"cat\": 21343423 } }' | \\\r\n    jq -r '.fmep | [.foo, .bar] | @tsv'\r\n\r\nwhich produces tab-separated\r\n\r\n    112\t234324",
      "Here is the syntax using joined output (`-j`):\r\n\r\n    jq -j '.fmep | .foo, \" \", .bar, \"\\n\"' payload.json"
    ],
    "utterance": "Print the values of foo and bar from the fmep object on the same line, separated by a space.",
    "expressions": [
      ".fmep | \"\\(.foo) \\(.bar)\"",
      ".fmep | [.foo, .bar] | @tsv",
      ".fmep | .foo, \" \", .bar, \"\\n\""
    ],
    "data": [
      {
        "input": {
          "fmep": {
            "foo": 112,
            "bar": 234324,
            "cat": 21343423
          }
        },
        "output": "112 234324"
      }
    ],
    "identifier": 46131727
  },
  {
    "context": [
      "I want to update the value field to \"two\". So resulting json file should look like",
      "jq -M '.value=\"two\"' < data.json | sponge data.json"
    ],
    "utterance": "Update the value field to \"two\" in the file, replacing the original file with the modified content.",
    "expressions": [
      "jq -M '.value=\"two\"' < data.json | sponge data.json"
    ],
    "data": [
      {
        "input": {
          "name": "app",
          "value": "one"
        },
        "output": {
          "name": "app",
          "value": "two"
        }
      }
    ],
    "identifier": 46169239
  },
  {
    "context": [
      "I would like to get the number of of JSON which contain a specific value.",
      "So in case I'm looking for value1 in key, the result should be 2.",
      "map(select(.key == \"value1\")) | length",
      "[ .[] | select(.key == \"value1\") ] | length",
      "def count(s; cond): reduce s as $x (0; if ($x|cond) then .+1 else . end);",
      "count(.[]; .key == \"value1\")"
    ],
    "utterance": "Count the objects in an array where the field key equals value1.",
    "expressions": [
      "map(select(.key == \"value1\")) | length",
      "[ .[] | select(.key == \"value1\") ] | length",
      "def count(s; cond): reduce s as $x (0; if ($x|cond) then .+1 else . end); count(.[]; .key == \"value1\")"
    ],
    "data": [
      {
        "input": [
          {
            "key": "value1",
            "2ndKey": "2ndValue1"
          },
          {
            "key": "value2",
            "2ndKey": "2ndValue2"
          },
          {
            "key": "value1",
            "2ndKey": "2ndValue3"
          }
        ],
        "output": 2
      }
    ],
    "identifier": 46182398
  },
  {
    "context": [
      "The output I need to generate is as follow:",
      "sg-xxxxxx|database|22|22|tcp|10.200.0.0/16",
      "sg-xxxxxx|database|22|22|tcp|10.200.30.79/32",
      "sg-xxxxxx|database|22|22|tcp|10.200.42.0/24",
      "sg-xxxxxx|database|5555|5555|tcp|10.200.0.0/16",
      "sg-xxxxxx|database|5555|5555|tcp|10.200.0.155/32",
      "sg-xxxxxx|database|4506|4506|tcp|10.200.0.0/16",
      "Here is a more efficient approach.  With the `-r` option, the following filter",
      ".SecurityGroups[]\n  | .GroupId as $gid\n  | .GroupName as $gname\n  | (.IpPermissions[], .IpPermissionsEgress[]?)\n  | .FromPort as $from\n  | .ToPort as $to\n  | .IpProtocol as $pro\n  | .IpRanges[]\n  | \"\\($gid)|\\($gname)|\\($from)|\\($to)|\\($pro)|\\(.CidrIp)\"",
      "with the sample data produces",
      "sg-xxxxxx|database|22|22|tcp|10.200.0.0/16",
      "sg-xxxxxx|database|22|22|tcp|10.200.30.79/32",
      "sg-xxxxxx|database|22|22|tcp|10.200.42.0/24",
      "sg-xxxxxx|database|5555|5555|tcp|10.200.0.0/16",
      "sg-xxxxxx|database|5555|5555|tcp|10.200.0.155/32",
      "sg-xxxxxx|database|4506|4506|tcp|10.200.0.0/16"
    ],
    "utterance": "List all combinations of GroupId, GroupName, FromPort, ToPort, IpProtocol, and each CidrIp from all SecurityGroups, including both IpPermissions and IpPermissionsEgress, formatted as groupid|groupname|fromport|toport|ipprotocol|cidrip.",
    "expressions": [
      ".SecurityGroups[]\n  | .GroupId as $gid\n  | .GroupName as $gname\n  | (.IpPermissions[], .IpPermissionsEgress[]?)\n  | .FromPort as $from\n  | .ToPort as $to\n  | .IpProtocol as $pro\n  | .IpRanges[]\n  | \"\\($gid)|\\($gname)|\\($from)|\\($to)|\\($pro)|\\(.CidrIp)\""
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "GroupName": "database",
              "GroupId": "sg-xxxxxx",
              "VpcId": "vpc-yyyyyyy",
              "IpPermissions": [
                {
                  "FromPort": 22,
                  "ToPort": 22,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "10.200.0.0/16"
                    },
                    {
                      "CidrIp": "10.200.30.79/32"
                    },
                    {
                      "CidrIp": "10.200.42.0/24"
                    }
                  ],
                  "UserIdGroupPairs": []
                },
                {
                  "FromPort": 5555,
                  "ToPort": 5555,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "10.200.0.0/16"
                    },
                    {
                      "CidrIp": "10.200.0.155/32"
                    }
                  ],
                  "UserIdGroupPairs": []
                },
                {
                  "FromPort": 4506,
                  "ToPort": 4506,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "10.200.0.0/16"
                    }
                  ],
                  "UserIdGroupPairs": []
                }
              ]
            }
          ]
        },
        "output": [
          "sg-xxxxxx|database|22|22|tcp|10.200.0.0/16",
          "sg-xxxxxx|database|22|22|tcp|10.200.30.79/32",
          "sg-xxxxxx|database|22|22|tcp|10.200.42.0/24",
          "sg-xxxxxx|database|5555|5555|tcp|10.200.0.0/16",
          "sg-xxxxxx|database|5555|5555|tcp|10.200.0.155/32",
          "sg-xxxxxx|database|4506|4506|tcp|10.200.0.0/16"
        ]
      }
    ],
    "identifier": 46137642
  },
  {
    "context": [
      "The variable contains the quotation marks \"\".",
      "How to remove the quotes when reading a variable in jq?",
      "But is there a way to just strip the quotes when reading from jq?"
    ],
    "utterance": "Obtain the value of the key 'greater_bash' as a string without surrounding quotes.",
    "expressions": [
      ".[\"greater_bash\"] | tonumber",
      ".[\"greater_bash\"] | @sh",
      ".[\"greater_bash\"] | @csv",
      "-r .[\"greater_bash\"]"
    ],
    "data": [
      {
        "input": {
          "dagger": true,
          "version": false,
          "nether_strike": true,
          "greater_bash": "5",
          "FILE": "ancientscroll.txt",
          "empower_haste": "1",
          "help": false
        },
        "output": "5"
      }
    ],
    "identifier": 46188224
  },
  {
    "context": [
      "Is there a way to read all key-value pairs in the JSON file and then initialize all variables accordingly in shell?",
      "while read -r name value; do\n    declare \"$name=$value\"\ndone < <(jq -r 'to_entries[] | \"\\(.key) \\(.value)\"' arguments.json)"
    ],
    "utterance": "Extract all key-value pairs as plain lines with keys and their corresponding values, suitable for looping and variable assignment in a shell script.",
    "expressions": [
      "to_entries[] | \"\\(.key) \\(.value)\"",
      "-r 'to_entries[] | \"\\(.key) \\(.value)\"'"
    ],
    "data": [
      {
        "input": {
          "dagger": true,
          "version": false,
          "nether_strike": true,
          "greater_bash": "5",
          "FILE": "ancientscroll.txt",
          "empower_haste": "1",
          "help": false
        },
        "output": [
          "dagger true",
          "version false",
          "nether_strike true",
          "greater_bash 5",
          "FILE ancientscroll.txt",
          "empower_haste 1",
          "help false"
        ]
      }
    ],
    "identifier": 46187807
  },
  {
    "context": [
      "I have an array of objects of various types which reference one another with UUIDs (a terraform.tfstate file). I&#39;d like to select one value from one such object based on the appearance of a different value in another object, where the two objects are related by one of those UUIDs.",
      "By way of example, I can do this:\r\n\r\n    $ jq '.modules[].resources[]\r\n    | select(.type == \"openstack_compute_instance_v2\" and \r\n             .primary.attributes.name == \"jumpbox\").primary.id' terraform.tfstate\r\n    \"5edfe2bf-94df-49d5-8118-3e91fb52946b\"\r\n    $ jq '.modules[].resources[] \r\n    | select(.type ==\"openstack_compute_floatingip_associate_v2\" and \r\n             .primary.attributes.instance_id == \"5edfe2bf-94df-49d5-8118-3e91fb52946b\").primary.attributes.floating_ip' terraform.tfstate\r\n    \"10.120.241.21\"\r\n\r\nGiving me the external floating IP of the 'jumpbox' VM based on its name.",
      "I&#39;d like to make that all one jq call. Is that possible?",
      "The following filter demonstrates a solution using [functions](https://stedolan.github.io/jq/manual/#DefiningFunctions), [variables](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) and [parenthesis ()](https://stedolan.github.io/jq/manual/#Parenthesis):",
      "def get_primary_id($name):\n    select(.type == \"openstack_compute_instance_v2\"\n       and .primary.attributes.name == $name)\n  | .primary.id\n;\ndef get_floating_ip($id):\n    select(.type ==\"openstack_compute_floatingip_associate_v2\"\n       and .primary.attributes.instance_id == $id)\n  | .primary.attributes.floating_ip\n;\n  .modules[]\n| ( .resources[] | get_primary_id(\"jumpbox\") ) as $id\n| ( .resources[] | get_floating_ip($id)      ) as $fip\n| ($id, $fip)"
    ],
    "utterance": "Return the external floating IP address for the VM whose name is 'jumpbox'.",
    "expressions": [
      "def get_primary_id($name):\n  select(.type == \"openstack_compute_instance_v2\" and .primary.attributes.name == $name)\n  | .primary.id;\ndef get_floating_ip($id):\n  select(.type ==\"openstack_compute_floatingip_associate_v2\" and .primary.attributes.instance_id == $id)\n  | .primary.attributes.floating_ip;\n.modules[]\n| ( .resources[] | get_primary_id(\"jumpbox\") ) as $id\n| ( .resources[] | get_floating_ip($id) )"
    ],
    "data": [
      {
        "input": {
          "modules": [
            {
              "resources": [
                {
                  "type": "openstack_compute_instance_v2",
                  "primary": {
                    "id": "5edfe2bf-94df-49d5-8118-3e91fb52946b",
                    "attributes": {
                      "name": "jumpbox"
                    }
                  }
                },
                {
                  "type": "openstack_compute_floatingip_associate_v2",
                  "primary": {
                    "attributes": {
                      "instance_id": "5edfe2bf-94df-49d5-8118-3e91fb52946b",
                      "floating_ip": "10.120.241.21"
                    }
                  }
                }
              ]
            }
          ]
        },
        "output": [
          "5edfe2bf-94df-49d5-8118-3e91fb52946b",
          "10.120.241.21"
        ]
      }
    ],
    "identifier": 46181542
  },
  {
    "context": [
      "Now I want to pipe each Key,Value to the following command:\r\n\r\n    aws ec2 create-tags --resources XXXXX --tags Key=H-KEY,Value=H-VALUE",
      "It's like: For each Key,Value, do:\r\n\r\n    aws ec2 create-tags --resources XXXXX --tags Key=A-KEY,Value=A-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=B-KEY,Value=B-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=C-KEY,Value=C-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=N...-KEY,Value=N...-VALUE",
      "aws ec2 describe-tags --filters \"Name=resource-id,Values=$INSTANCE_ID\" \\\r\n| jq -r '.Tags[] | @sh \"aws ec2 create-tags --resources XXXXX --tags Key=\\(.Key),Value=\\(.Value)\"'",
      "jq is quite an adventure. You need to add a \"select\" filter to remove keys that start with \"aws:\"\r\n\r\n    jq -r '\r\n        .Tags[] | \r\n        select(.Key | test(\"^aws:\") | not) |\r\n        @sh \"aws ... --tags Key=\\(.Key),Value=\\(.Value)\"\r\n    '"
    ],
    "utterance": "For each object in the Tags array, produce a shell command using its Key and Value fields formatted as aws ec2 create-tags --resources XXXXX --tags Key=...,Value=....",
    "expressions": [
      ".Tags[] | @sh \"aws ec2 create-tags --resources XXXXX --tags Key=\\(.Key),Value=\\(.Value)\"",
      ".Tags[] | select(.Key | test(\"^aws:\") | not) | @sh \"aws ec2 create-tags --resources XXXXX --tags Key=\\(.Key),Value=\\(.Value)\""
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "A-VALUE",
              "Key": "A-KEY"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "B-VALUE",
              "Key": "B-KEY"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "C-VALUE",
              "Key": "C-KEY"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "D-VALUE",
              "Key": "D-KEY"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "E-VALUE",
              "Key": "E-KEY"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-0342a609edf80001a",
              "Value": "F-VALUE",
              "Key": "G-KEY"
            }
          ]
        },
        "output": [
          "aws ec2 create-tags --resources XXXXX --tags Key='A-KEY',Value='A-VALUE'",
          "aws ec2 create-tags --resources XXXXX --tags Key='B-KEY',Value='B-VALUE'",
          "aws ec2 create-tags --resources XXXXX --tags Key='C-KEY',Value='C-VALUE'",
          "aws ec2 create-tags --resources XXXXX --tags Key='D-KEY',Value='D-VALUE'",
          "aws ec2 create-tags --resources XXXXX --tags Key='E-KEY',Value='E-VALUE'",
          "aws ec2 create-tags --resources XXXXX --tags Key='G-KEY',Value='F-VALUE'"
        ]
      }
    ],
    "identifier": 46177546
  },
  {
    "context": [
      "I need output as below:",
      "    {",
      "    \"imageName\" : \"build-server:159\",",
      "    \"volumesFrom\" : [",
      "            \"buildtype-mock:218\",",
      "            \"buildtype-se:540-1.0.5-V30.1-GA\",",
      "            \"buildtype-nodejs:42\",",
      "            \"buildtype-flogo:682\"",
      "          ]",
      "    }",
      "map(      ",
      "   select(.appId == \"server2\")",
      "|  .scaleApp",
      "| {imageName, volumesFrom}",
      "| .imageName |= .[8:]",
      "| .volumesFrom[] |= .[8:]",
      ")[]",
      "produces only",
      "    {",
      "      \"imageName\": \"build-server:159\",",
      "      \"volumesFrom\": [",
      "        \"buildtype-mock:218\",",
      "        \"buildtype-se:540-1.0.5-V30.1-GA\",",
      "        \"buildtype-nodejs:42\",",
      "        \"buildtype-flogo:682\"",
      "      ]",
      "    }",
      "for `.appId == \"server2\"`"
    ],
    "utterance": "Extract imageName and volumesFrom from the scaleApp of the object where appId is 'server2', removing the '${DATA}/' prefix from each value.",
    "expressions": [
      "map(\n   select(.appId == \"server2\")\n|  .scaleApp\n| {imageName, volumesFrom}\n| .imageName |= .[8:]\n| .volumesFrom[] |= .[8:]\n)[]"
    ],
    "data": [
      {
        "input": [
          {
            "appId": "server1",
            "userName": "bhavik",
            "scaleApp": {
              "imageName": "${DATA}/build-server:1",
              "internalPath": "/",
              "volumesFrom": [
                "${DATA}/buildtype-mock:219",
                "${DATA}/buildtype-se:543-1.0.5-V30.2-GA"
              ]
            }
          },
          {
            "appId": "server2",
            "userName": "rajiv",
            "scaleApp": {
              "imageName": "${DATA}/build-server:159",
              "internalPath": "/",
              "volumesFrom": [
                "${DATA}/buildtype-mock:218",
                "${DATA}/buildtype-se:540-1.0.5-V30.1-GA",
                "${DATA}/buildtype-nodejs:42",
                "${DATA}/buildtype-flogo:682"
              ]
            }
          }
        ],
        "output": {
          "imageName": "build-server:159",
          "volumesFrom": [
            "buildtype-mock:218",
            "buildtype-se:540-1.0.5-V30.1-GA",
            "buildtype-nodejs:42",
            "buildtype-flogo:682"
          ]
        }
      }
    ],
    "identifier": 46169164
  },
  {
    "context": [
      "Then for testing I just tried to get the uri of all bookmarks (later I will extract other datas too) but this didn't work",
      "Here is a solution using [tostream](https://stedolan.github.io/jq/manual/#tostream):",
      "tostream                       # read [[path],value] and [[path]] stream",
      "| select(length==2) as [$p,$v]   # put [path] in $p and value in $v",
      "| select($p[-1] == \"uri\")        # keep paths ending in \"uri\"",
      "| $v                             # emit value",
      "Then the command",
      "$ jq -Mr -f filter.jq data.json",
      "produces",
      "https://stackoverflow.com/"
    ],
    "utterance": "Extract all values associated with the key 'uri' from nested bookmark data.",
    "expressions": [
      "tostream | select(length==2) as [$p,$v] | select($p[-1] == \"uri\") | $v"
    ],
    "data": [
      {
        "input": {
          "guid": "root________",
          "title": "",
          "index": 0,
          "dateAdded": 1000000000000000,
          "lastModified": 1000000000000000,
          "id": 1,
          "type": "text/x-moz-place-container",
          "root": "placesRoot",
          "children": [
            {
              "guid": "menu________",
              "title": "Bookmarks Menu",
              "index": 0,
              "dateAdded": 1000000000000000,
              "lastModified": 1000000000000000,
              "id": 2,
              "type": "text/x-moz-place-container",
              "root": "bookmarksMenuFolder",
              "children": [
                {
                  "guid": "ygE5SOG8IWid",
                  "title": "Stack Overflow",
                  "index": 0,
                  "dateAdded": 1000000000000000,
                  "lastModified": 1000000000000000,
                  "id": 3,
                  "iconuri": "https://cdn.sstatic.net/Sites/stackoverflow/img/favicon.ico?v=4f32ecc8f43d",
                  "annos": [
                    {
                      "name": "bookmarkProperties/description",
                      "flags": 0,
                      "expires": 4,
                      "value": "Stack Overflow is the largest, most trusted online community for developers to learn, share\u200b \u200btheir programming \u200bknowledge, and build their careers."
                    }
                  ],
                  "type": "text/x-moz-place",
                  "uri": "https://stackoverflow.com/"
                }
              ]
            }
          ]
        },
        "output": "https://stackoverflow.com/"
      }
    ],
    "identifier": 46206367
  },
  {
    "context": [
      "I would like to replace the contents of some of the \"value\" keys with data from a mysql query that takes the former value as argument.",
      "if the mysql query returned\n\n      183213,\n      834924,\n      986312,\n      987312\n\nthe object would become\n\n  {\n    ...\n    \"value\": [\n      183213,\n      834924,\n      986312,\n      987312\n    ],\n    ...\n  }",
      "jq --arg new_vals \"$new_values\" '.[] | if(.item.name == \"elementName\" and .operator == \"in\")\n                   then .value |= ($new_vals | split(\",\")) else empty end' input.json",
      "Here is a general solution using [jq](https://stedolan.github.io/jq/) and the `--argfile` option.",
      "[\n  {\n    \"from\": [\"NEHVN_3_NOIRSC3_1\",\"NGNHU_5_NGNHU_5_1\",\"NMVL381_NMDC381_1\",\"XGR_MA1_NMDC381_1\"],\n    \"to\":   [183213, 834924, 986312, 987312]\n  }\n]",
      "If this table is in the file `repl.json`, your data is in `data.json` and the following filter is in the file `filter.jq`\n\n  $replacements[] as $r\n| map(if .value==$r.from then .value=$r.to else . end)",
      "then the command\n\n$ jq -M --argfile replacements repl.json -f filter.jq data.json\n\nwill produce the output with the substituted values."
    ],
    "utterance": "Replace the array values of the key \"value\" for all objects with .item.name == \"elementName\" and .operator == \"in\" with a new array, such as the one produced by a lookup or query.",
    "expressions": [
      ".[] | if(.item.name == \"elementName\" and .operator == \"in\") then .value |= ($new_vals | split(\",\")) else empty end",
      "$replacements[] as $r | map(if .value==$r.from then .value=$r.to else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "item": {
              "name": "elementName",
              "type": "table",
              "displayName": "Element name",
              "operators": [
                "in",
                "not in",
                "=",
                "<>",
                "like"
              ],
              "values": []
            },
            "operator": "in",
            "value": [
              "NEHVN_3_NOIRSC3_1",
              "NGNHU_5_NGNHU_5_1",
              "NMVL381_NMDC381_1",
              "XGR_MA1_NMDC381_1"
            ],
            "conjunction": "or",
            "level": 2,
            "userFriendlyValue": [
              "NEHVN_3_NOIRSC3_1",
              "NGNHU_5_NGNHU_5_1",
              "NMVL381_NMDC381_1",
              "XGR_MA1_NMDC381_1"
            ]
          }
        ],
        "output": [
          {
            "item": {
              "name": "elementName",
              "type": "table",
              "displayName": "Element name",
              "operators": [
                "in",
                "not in",
                "=",
                "<>",
                "like"
              ],
              "values": []
            },
            "operator": "in",
            "value": [
              183213,
              834924,
              986312,
              987312
            ],
            "conjunction": "or",
            "level": 2,
            "userFriendlyValue": [
              "NEHVN_3_NOIRSC3_1",
              "NGNHU_5_NGNHU_5_1",
              "NMVL381_NMDC381_1",
              "XGR_MA1_NMDC381_1"
            ]
          }
        ]
      }
    ],
    "identifier": 46076664
  },
  {
    "context": [
      "Using jq, I am filtering the object based on ImportTaskId and printing Status and StatusMessage.",
      "jq '.ImportImageTasks[] | select(.ImportTaskId==\"import-ami-123456\") | .ImportTaskId,.Status,.StatusMessage' <<< \"$pollresp\"",
      ".ImportImageTasks[] | select(.ImportTaskId==\"import-ami-123456\") | [.ImportTaskId, .Status, .StatusMessage] | @tsv"
    ],
    "utterance": "Extract the ImportTaskId, Status, and StatusMessage fields from the object where ImportTaskId equals import-ami-123456, preserving all spaces in the StatusMessage output.",
    "expressions": [
      ".ImportImageTasks[] | select(.ImportTaskId==\"import-ami-123456\") | .ImportTaskId,.Status,.StatusMessage",
      ".ImportImageTasks[] | select(.ImportTaskId==\"import-ami-123456\") | [.ImportTaskId, .Status, .StatusMessage] | @tsv"
    ],
    "data": [
      {
        "input": {
          "ImportImageTasks": [
            {
              "Description": "SP",
              "ImportTaskId": "import-ami-123456",
              "Status": "deleted",
              "StatusMessage": "User initiated task cancelation"
            }
          ]
        },
        "output": [
          "\"import-ami-123456\"",
          "\"deleted\"",
          "\"User initiated task cancelation\""
        ]
      }
    ],
    "identifier": 46227984
  },
  {
    "context": [
      "Content replacement needs to be done based on `type` key's value.",
      "jq --slurpfile repl repl.json '.manipulate=[.manipulate[] | if .type==\"replace\" then .=$repl[0] else . end]' config.json",
      "jq --slurpfile repl repl.json '.manipulate |= map(if .type==\"replace\" then $repl[0] else . end)' config.json"
    ],
    "utterance": "Replace all elements in the 'manipulate' array whose 'type' is 'replace' with the content from an external file, while keeping the order and other elements unchanged.",
    "expressions": [
      ".manipulate=[.manipulate[] | if .type==\"replace\" then .=$repl[0] else . end]",
      ".manipulate |= map(if .type==\"replace\" then $repl[0] else . end)"
    ],
    "data": [
      {
        "input": {
          "keep": "whatever type of value",
          "manipulate": [
            {
              "foo": "bar",
              "cat": {
                "color": "grey"
              },
              "type": "keep",
              "detail": "keep whole array element"
            },
            {
              "stuff": "obsolete",
              "more_stuff": "obsolete",
              "type": "replace",
              "detail": "replace whole array element with content from separate file"
            },
            {
              "foz": "baz",
              "dog": {
                "color": "brown"
              },
              "type": "keep",
              "detail": "keep whole array element"
            }
          ],
          "also_keep": "whatever type of value"
        },
        "output": {
          "keep": "whatever type of value",
          "manipulate": [
            {
              "foo": "bar",
              "cat": {
                "color": "grey"
              },
              "type": "keep",
              "detail": "keep whole array element"
            },
            {
              "stuff": "i want that",
              "fancy": "very",
              "type": "new"
            },
            {
              "foz": "baz",
              "dog": {
                "color": "brown"
              },
              "type": "keep",
              "detail": "keep whole array element"
            }
          ],
          "also_keep": "whatever type of value"
        }
      },
      {
        "input": {
          "stuff": "i want that",
          "fancy": "very",
          "type": "new"
        }
      }
    ],
    "identifier": 46216346
  },
  {
    "context": [
      "I have the the following child objects contained within an array \u201c`entries`\u201d",
      "I wish to convert these to an array accessible by bash via the jq function \u201c`to_entries`\u201d",
      "    .profile.download.entries[]",
      "    | select(.store == \"A\")",
      "    | to_entries[]",
      "    | select(.key != \"store\")",
      "    | select(.key != \"type\")",
      "    | [.key, .value]",
      "    | @tsv",
      ".profile.download.entries[] | select(.store == \"A\") | .entry, .store, .type"
    ],
    "utterance": "Extract objects from the 'entries' array where 'store' equals \"A\".",
    "expressions": [
      ".profile.download.entries[] | select(.store == \"A\")",
      ".profile.download.entries[] | select(.store == \"A\") | to_entries[] | select(.key != \"store\") | select(.key != \"type\") | [.key, .value] | @tsv"
    ],
    "data": [
      {
        "input": {
          "profile": {
            "name": "TesterRun1",
            "download": {
              "entries": [
                {
                  "ENTRY_A": "testserver1_place_com",
                  "store": "A",
                  "type": "direct"
                },
                {
                  "ENTRY_B": "testserver2_anotherplace_com",
                  "store": "B",
                  "type": "bypass"
                },
                {
                  "ENTRY_B": "testserver2_anotherplace_com",
                  "store": "A",
                  "type": "bypass"
                }
              ]
            }
          }
        },
        "output": [
          {
            "ENTRY_A": "testserver1_place_com",
            "store": "A",
            "type": "direct"
          },
          {
            "ENTRY_B": "testserver2_anotherplace_com",
            "store": "A",
            "type": "bypass"
          }
        ]
      }
    ],
    "identifier": 46229097
  },
  {
    "context": [
      "example:  \r\nin `{\"x\": {\"y\": 5}}`, y should be changed to 123,  \r\nbut in `{\"x\": {\"z\": 9}}`, nothing should change.",
      "jq -Mnc '\r\n      {\"x\": {\"y\": 5}} | if .x.y != null then .x.y = 123 else . end\r\n    , {\"x\": {\"z\": 9}} | if .x.y != null then .x.y = 123 else . end\r\n'",
      "With built-in `has()` function:\r\n\r\n    jq -nc '{\"x\":{\"y\": 5}} | if (.x | has(\"y\")) then .x.y=123 else empty end'",
      "if has(\"x\") and (.x | has(\"y\")) then .x.y = 123 else . end\r\n<br/>\r\n\r\n    if .x.y? then .x.y = 123 else . end"
    ],
    "utterance": "Update the value of y to 123 only if y exists under x; do nothing if y does not exist.",
    "expressions": [
      "if .x.y != null then .x.y = 123 else . end",
      "if (.x | has(\"y\")) then .x.y=123 else . end",
      "if has(\"x\") and (.x | has(\"y\")) then .x.y = 123 else . end",
      "if .x.y? then .x.y = 123 else . end"
    ],
    "data": [
      {
        "input": {
          "x": {
            "y": 5
          }
        },
        "output": {
          "x": {
            "y": 123
          }
        }
      },
      {
        "input": {
          "x": {
            "z": 9
          }
        },
        "output": {
          "x": {
            "z": 9
          }
        }
      }
    ],
    "identifier": 46248576
  },
  {
    "context": [
      "I have a JSON list which I want to merge on command line .",
      "Input: [ { \"ipaddress\": \"10.10.10.222\", \"name\": \"alice\" }, { \"ipaddress\": \"10.20.20.77\", \"name\": \"bob\" }, { \"version\": \"6.7\", \"name\": \"alice\" }, { \"version\": \"5.2.2\", \"name\": \"bob\" } ]",
      "Expected Output: {\"name\": \"alice\", \"ipaddress\": \"10.10.10.222\", \"version\": \"6.7\"}, {\"name\": \"bob\", \"ipaddress\": \"10.20.20.77\", \"version\": \"5.2.2\"}",
      "$ jq -M '[group_by(.name)[] | add]' data.json",
      "jq -c 'group_by(.name)[]|add' input.json",
      "def add_by(f): reduce .[] as $x ({}; ($x|f) as $f | .[$f] += [$x]) | [.[] | add]; add_by(.name)"
    ],
    "utterance": "Merge objects by their 'name' field so that for each unique name, all fields from objects with that name are combined into a single object.",
    "expressions": [
      "[group_by(.name)[] | add]",
      "group_by(.name)[]|add",
      "def add_by(f): reduce .[] as $x ({}; ($x|f) as $f | .[$f] += [$x]) | [.[] | add]; add_by(.name)"
    ],
    "data": [
      {
        "input": [
          {
            "ipaddress": "10.10.10.222",
            "name": "alice"
          },
          {
            "ipaddress": "10.20.20.77",
            "name": "bob"
          },
          {
            "version": "6.7",
            "name": "alice"
          },
          {
            "version": "5.2.2",
            "name": "bob"
          }
        ],
        "output": [
          {
            "ipaddress": "10.10.10.222",
            "name": "alice",
            "version": "6.7"
          },
          {
            "ipaddress": "10.20.20.77",
            "name": "bob",
            "version": "5.2.2"
          }
        ]
      }
    ],
    "identifier": 46254655
  },
  {
    "context": [
      "With the help of this line : `echo $jstring | jq '.[] | [.user, .userQuery]'`. I am able to extract below info: \r\n\r\n    [ \"abc\", \"select name from abc;\"][ \"xyz\", \"select name from xyz;\"][ \"ppp\", \"select name from ppp;\"]",
      "Now, I want two variable \"user\" & \"query\" for each array and store that info. <br />\r\nEg: For [ \"abc\", \"select name from abc;\"] -- user: abc, query: \"select name from abc\" and store them.",
      "The secret sauce is in the formulation of the string inside jq that refers to the object properties with `\\(.user)`",
      "while IFS=$'\\t' read -r user query; do\r\n    msg=\"User: ${user} is running : ${query}\"\r\n    mail -s \"User query\" \"youremail@gmail.com\" <<< \"$msg\"\r\ndone < <(jq '.[] | [.user,.userQuery] | @tsv' <<< \"$jstring\")"
    ],
    "utterance": "Extract user and userQuery values as separate fields for each element in an array where each element contains user and userQuery keys.",
    "expressions": [
      ".[] | \"\\(.user) \\(.userQuery)\"",
      ".[] | [.user, .userQuery] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "userQuery": "select name from abc;",
            "user": "abc"
          },
          {
            "userQuery": "select name from xyz;",
            "user": "xyz"
          },
          {
            "userQuery": "select name from ppp;",
            "user": "ppp"
          }
        ],
        "output": [
          "abc select name from abc;",
          "xyz select name from xyz;",
          "ppp select name from ppp;"
        ]
      }
    ],
    "identifier": 46257850
  },
  {
    "context": [
      "How I round digit on the last column to 2 decimal places?",
      "I use JQ to get csv data:",
      "[\"Name\",\"Description\",\"Result\"],(.hits.hits[]._source | [.acb.item.name,.acb.item.description,.value])|@csv",
      "but I want **210.09** and **370.21**",
      "def roundit: .*100.0|round/100.0;",
      "[\"Name\",\"Description\",\"Result\"],\n(.hits.hits[]._source | [.acb.item.name, .acb.item.description, (.value|roundit)])\n    | @csv",
      "def roundit: .*100.0 + 0.5|floor/100.0;",
      "def round:                                                # e.g.\n    (split(\".\") + [\"0\"])[:2]                              # [\"210\",\"08691986891395\"]\n  | \"\\(.[1])000\"[:3] as $x | [.[0], $x[:2], $x[2:3]]      # [\"210\",\"08\",\"6\"]\n  | map(tonumber)                                         # [210,8,6]\n  | if .[2] >  4 then .[2] = 0 | .[1] += 1 else . end     # [210,9,0]\n  | if .[1] > 99 then .[1] = 0 | .[0] += 1 else . end     # [210,9,0]\n  | [\"\\(.[0])\", \"00\\(.[1])\"[-2:]]                         # [\"210\",\"09\"]\n  | join(\".\")                                             # 210.09\n;",
      "(   [\"Name\", \"Description\", \"Result\"] | @csv )\n, (   .hits.hits[]._source\n    | [.acb.item.name, .acb.item.description, .value]\n    | @csv\n    | split(\",\") | .[-1] |= round | join(\",\")\n  )"
    ],
    "utterance": "Output data rows where the value in the last column is rounded to two decimal places.",
    "expressions": [
      "def roundit: .*100.0|round/100.0; [\"Name\",\"Description\",\"Result\"], (.hits.hits[]._source | [.acb.item.name, .acb.item.description, (.value|roundit)]) | @csv",
      "def roundit: .*100.0 + 0.5|floor/100.0; [\"Name\",\"Description\",\"Result\"], (.hits.hits[]._source | [.acb.item.name, .acb.item.description, (.value|roundit)]) | @csv",
      "def round: (split(\".\") + [\"0\"])[:2] | \"\\(.[1])000\"[:3] as $x | [.[0], $x[:2], $x[2:3]] | map(tonumber) | if .[2] >  4 then .[2] = 0 | .[1] += 1 else . end | if .[1] > 99 then .[1] = 0 | .[0] += 1 else . end | [\"\\(.[0])\", \"00\\(.[1])\"[-2:]] | join(\".\"); ( [\"Name\", \"Description\", \"Result\"] | @csv ), ( .hits.hits[]._source | [.acb.item.name, .acb.item.description, .value] | @csv | split(\",\") | .[-1] |= round | join(\",\") )"
    ],
    "data": [
      {
        "input": {
          "took": 1,
          "timed_out": false,
          "_shards": {
            "total": 9,
            "successful": 9,
            "failed": 0
          },
          "hits": {
            "total": 2,
            "max_score": 2.575364,
            "hits": [
              {
                "_index": "my-2017-08",
                "_type": "log",
                "_id": "AV5V8l0oDDWj-VP3YnCw",
                "_score": 2.575364,
                "_source": {
                  "acb": {
                    "version": 1,
                    "id": "7",
                    "owner": "pc",
                    "item": {
                      "name": "Account Average Latency",
                      "short_name": "Generate",
                      "description": "Generate of last month"
                    },
                    "service": "gsm"
                  },
                  "@timestamp": "2017-07-31T22:00:00.000Z",
                  "value": 210.08691986891395
                }
              },
              {
                "_index": "my-2017-08",
                "_type": "log",
                "_id": "AV5V8lbE28ShqBNuBl60",
                "_score": 2.575364,
                "_source": {
                  "acb": {
                    "version": 1,
                    "id": "5",
                    "owner": "pc",
                    "item": {
                      "name": "Profile Average Latency",
                      "short_name": "Profile",
                      "description": "Profile average latency of last month"
                    },
                    "service": "gsm"
                  },
                  "@timestamp": "2017-07-31T22:00:00.000Z",
                  "value": 370.20963260148716
                }
              }
            ]
          }
        },
        "output": [
          "\"Name\",\"Description\",\"Result\"",
          "\"Account Average Latency\",\"Generate of last month\",210.09",
          "\"Profile Average Latency\",\"Profile average latency of last month\",370.21"
        ]
      }
    ],
    "identifier": 46117049
  },
  {
    "context": [
      "How can I output just the `duration` values from below?",
      "If I search for `jq -r \".media.duration\"` then I get `nil`.",
      "You need to flatten the array returned by `episodes[1:]` by adding another set of brackets. Also, you skipped the resolution level (`\"720p\"`).  Putting that all together, this should work. It will output one duration value per line, unquoted:",
      "jq -r '.episodes[1:][].media[\"720p\"].duration'",
      "Use `map()`:",
      "$ cat test.json | jq -r '.episodes[1:] | map(.media[\"720p\"].duration)'",
      "Because `.episodes[1:]` gives you a list, you need to iter over it. [`map(<selector>)`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) is what you want here.",
      "Alternatively, you could flatten the list using [`.[]`](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]):",
      "$ cat test.json | jq -r \".episodes[1:] | .[] | .media[\\\"720p\\\"].duration\" ",
      "If you just want to pull any `duration` value in your json tree, you could just recurse and try to pull the `duration` discarding null results.",
      ".. | objects.duration? // empty",
      "To be more explicit and only pull `duration` values, you could analyze the paths to the values and select the `duration` values only.",
      "getpath(leaf_paths | select(.[-1] == \"duration\"))",
      "Here is a variation using [tostream](https://stedolan.github.io/jq/manual/#tostream).",
      "$ jq -Mr ' \n    tostream                        # generate [[path],value] pairs from input\n  | select(length==2) as [$p,$v]    # assign [path] to $p and value to $v\n  | select($p[-1]==\"duration\")      # keep paths ending in \"duration\"\n  | $v                              # emit value\n' data.json",
      "produces\n\n00:51:55\n00:51:55"
    ],
    "utterance": "Output all duration values inside episodes[1:], specifically under the media[\"720p\"] object.",
    "expressions": [
      ".episodes[1:][].media[\"720p\"].duration",
      ".episodes[1:] | map(.media[\"720p\"].duration)",
      ".episodes[1:] | .[] | .media[\"720p\"].duration",
      ".. | objects.duration? // empty",
      "getpath(leaf_paths | select(.[-1] == \"duration\"))",
      "tostream | select(length==2) as [$p,$v] | select($p[-1]==\"duration\") | $v"
    ],
    "data": [
      {
        "input": {
          "episodes": [
            {},
            {
              "uniqueHash": "a2dc48cd0f9",
              "startOffset": "{0}",
              "media": {
                "720p": {
                  "extension": "mp4",
                  "filesize": "1702",
                  "duration": "00:51:55"
                }
              }
            },
            {
              "uniqueHash": "a2d0f9",
              "startOffset": "{0}",
              "media": {
                "720p": {
                  "extension": "mp4",
                  "filesize": "12602",
                  "duration": "00:51:55"
                }
              }
            }
          ]
        },
        "output": [
          "00:51:55",
          "00:51:55"
        ]
      }
    ],
    "identifier": 46241435
  },
  {
    "context": [
      "I have json that looks like the below. I'd like to get an output that contains one line for each timer record, but includes the name of the service.",
      "The output that I'm expecting would be\n\n    [[\"Test Value\",\"08/30/2017 16:33:35\",\"625\"],[\"Test Value\",\"08/30/2017 16:22:38\",\"240\"]]\n    [[\"Test Value 2\",\"08/30/2017 16:07:38\",\"432\"],[\"Test Value 2\",\"08/30/2017 15:59:07\",\"1355\"]]",
      ".services.service[] | [ {name} + .timer[] | [.[]] ]\n    \ngenerates arrays of arrays for each service\n\n    [[\"Test Value\",\"08/30/2017 16:33:35\",\"625\"],[\"Test Value\",\"08/30/2017 16:22:38\",\"240\"]]\n    [[\"Test Value 2\",\"08/30/2017 16:07:38\",\"432\"],[\"Test Value 2\",\"08/30/2017 15:59:07\",\"1355\"]]",
      "Put together, this expression produces individual arrays of the name, datetime, and values but you want to collect them in an array. So put them in.\n\n    [[.name] + (.timer[] | [.datetime, .value])]\n\nWhen you put it all together, you'll get your result.\n\n    .services.service[] | [[.name] + (.timer[] | [.datetime, .value])]"
    ],
    "utterance": "For each service, return an array of arrays containing the service name, timer datetime, and timer value for every timer.",
    "expressions": [
      ".services.service[] | [ {name} + .timer[] | [.[]] ]",
      ".services.service[] | [ [ .name ] + (.timer[] | [.datetime, .value]) ]"
    ],
    "data": [
      {
        "input": {
          "services": {
            "service": [
              {
                "name": "Test Value",
                "timer": [
                  {
                    "datetime": "08/30/2017 16:33:35",
                    "value": "625"
                  },
                  {
                    "datetime": "08/30/2017 16:22:38",
                    "value": "240"
                  }
                ]
              },
              {
                "name": "Test Value 2",
                "timer": [
                  {
                    "datetime": "08/30/2017 16:07:38",
                    "value": "432"
                  },
                  {
                    "datetime": "08/30/2017 15:59:07",
                    "value": "1355"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          [
            [
              "Test Value",
              "08/30/2017 16:33:35",
              "625"
            ],
            [
              "Test Value",
              "08/30/2017 16:22:38",
              "240"
            ]
          ],
          [
            [
              "Test Value 2",
              "08/30/2017 16:07:38",
              "432"
            ],
            [
              "Test Value 2",
              "08/30/2017 15:59:07",
              "1355"
            ]
          ]
        ]
      }
    ],
    "identifier": 45982943
  },
  {
    "context": [
      "My goal however, is to search for these and add an extra \\n to the start of the matched \\n* lines.",
      "I don't appear to be able to do backreferences using gsub, so is there a similar functionality to what can be done in sed and vi using backreference matches in jq?",
      "Here is a demonstration using a named capture ?<a> with sub and gsub:",
      "sub(\"(?<a>\\n\\*[A-Za-z0-9]*\\n)\",\"\\n\\(.a)\",\"g\")",
      "gsub(\"(?<a>\\n\\*[A-Za-z0-9]*\\n)\",\"\\n\\(.a)\")",
      "\"\\n\\n*blah\\n**tim\\nbob was here\\n\\n*item1\\n**item2\\n\""
    ],
    "utterance": "Insert an extra newline at the start of each line that begins with a newline followed by an asterisk and alphanumeric characters, using a capture group as a backreference.",
    "expressions": [
      "sub(\"(?<a>\\n\\*[A-Za-z0-9]*\\n)\", \"\\n\\(.a)\", \"g\")",
      "gsub(\"(?<a>\\n\\*[A-Za-z0-9]*\\n)\", \"\\n\\(.a)\")"
    ],
    "data": [
      {
        "input": "\n*blah\n**tim\nbob was here\n*item1\n**item2\n",
        "output": "\n\n*blah\n**tim\nbob was here\n\n*item1\n**item2\n"
      }
    ],
    "identifier": 46323036
  },
  {
    "context": [
      "I wanted jq to return all top-level objects from the input that have array properties containing one of two specific values, but not both values.",
      "For example, given the input:\n\n    [\n      {\"letters\": [\"a\", \"c\"]},\n      {\"letters\": [\"a\", \"b\", \"c\"]},\n      {\"letters\": [\"b\", \"c\"]}\n    ]\n\nI want only the objects whose `\"letters\"` property contains either `\"a\"` or `\"b\"`, but not both.",
      "map(select(.letters//[]|((contains([\"a\"]) or contains([\"b\"])) and (contains([\"a\", \"b\"])|not))))",
      "def xor($a;$b): $a != $b ;\nmap(select(.letters|xor(contains([\"a\"]);contains([\"b\"]))))",
      "def xor($a;$b): ($a|not) != ($b|not) ;",
      "map(select(.letters|.[[\"a\"]]+.[[\"b\"]]|length==1))",
      "def xor($a;$b): ($a or $b) and (($a and $b)|not);",
      ".letters | select( xor( index(\"a\"); index(\"b\") ))",
      ".letters as $a | select( xor( \"a\" | IN($a[]); \"b\" | IN($a[]) ))"
    ],
    "utterance": "Return all objects where the \"letters\" array contains either \"a\" or \"b\", but not both.",
    "expressions": [
      "map(select(.letters//[]|((contains([\"a\"]) or contains([\"b\"])) and (contains([\"a\", \"b\"])|not))))",
      "def xor($a;$b): $a != $b ; map(select(.letters|xor(contains([\"a\"]);contains([\"b\"]))))",
      "def xor($a;$b): ($a|not) != ($b|not) ; map(select(.letters|xor(contains([\"a\"]);contains([\"b\"]))))",
      "map(select(.letters|.[[\"a\"]]+.[[\"b\"]]|length==1))",
      "def xor($a;$b): ($a or $b) and (($a and $b)|not); map(select(.letters|xor(contains([\"a\"]);contains([\"b\"]))))",
      "map(select(.letters|xor(index(\"a\");index(\"b\"))))",
      "map(select(.letters as $a | xor(\"a\"|IN($a[]); \"b\"|IN($a[]))))"
    ],
    "data": [
      {
        "input": [
          {
            "letters": [
              "a",
              "c"
            ]
          },
          {
            "letters": [
              "a",
              "b",
              "c"
            ]
          },
          {
            "letters": [
              "b",
              "c"
            ]
          }
        ],
        "output": [
          {
            "letters": [
              "a",
              "c"
            ]
          },
          {
            "letters": [
              "b",
              "c"
            ]
          }
        ]
      }
    ],
    "identifier": 46308139
  },
  {
    "context": [
      "I need to select all entries of \"items\" list which do not have \"spec.taints[].effect == \"NoSchedule\".",
      "The thing is that presence of taints list and effect key is not mandatory in source JSON so I cannot do:\n\n    select (.spec.taints[].effect != \"NoSchedule\")",
      "jq '[.items[] | if (.spec | has(\"taints\") | not) \n        or (.spec.taints[] | select(.effect!=\"NoSchedule\")) then . else empty end]' your.json",
      "You could use `?` to ignore any errors if a given property or array doesn't exist. So with that in mind, go through the items where none of them contain a taint effect of `\"NoSchedule\"`.\n\n    .items[] | select(all(.spec.taints[]?; .effect != \"NoSchedule\"))",
      "Here is a filter which should work. \n\n       .items[]\n     | select(.spec.taints | (.==null) or (any(.effect==\"NoSchedule\")|not))"
    ],
    "utterance": "Select all items where no taint effect equals NoSchedule, handling possible absence of 'taints' or 'effect'.",
    "expressions": [
      "[.items[] | if (.spec | has(\"taints\") | not) or (.spec.taints[] | select(.effect!=\"NoSchedule\")) then . else empty end]",
      ".items[] | select(all(.spec.taints[]?; .effect != \"NoSchedule\"))",
      ".items[] | select(.spec.taints | (.==null) or (any(.effect==\"NoSchedule\")|not))"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "apiVersion": "v1",
              "kind": "Node",
              "metadata": {
                "annotations": {
                  "node.alpha.kubernetes.io/ttl": "0",
                  "volumes.kubernetes.io/controller-managed-attach-detach": "true"
                },
                "creationTimestamp": "2017-09-14T11:53:07Z",
                "labels": {
                  "beta.kubernetes.io/arch": "amd64",
                  "beta.kubernetes.io/os": "linux",
                  "kubernetes.io/hostname": "msl-kub01.int.na.myapp.com",
                  "node-role.kubernetes.io/master": ""
                },
                "name": "msl-kub01.int.na.myapp.com",
                "namespace": "",
                "resourceVersion": "123154",
                "selfLink": "/api/v1/nodes/msl-kub01.int.na.myapp.com",
                "uid": "45e3b430-9943-11e7-bf0b-fa163e6604fc"
              },
              "spec": {
                "externalID": "msl-kub01.int.na.myapp.com",
                "taints": [
                  {
                    "effect": "NoSchedule",
                    "key": "node-role.kubernetes.io/master",
                    "timeAdded": null
                  }
                ]
              }
            },
            {
              "apiVersion": "v1",
              "kind": "Node",
              "metadata": {
                "annotations": {
                  "node.alpha.kubernetes.io/ttl": "0",
                  "volumes.kubernetes.io/controller-managed-attach-detach": "true"
                },
                "creationTimestamp": "2017-09-14T12:05:42Z",
                "labels": {
                  "beta.kubernetes.io/arch": "amd64",
                  "beta.kubernetes.io/os": "linux",
                  "kubernetes.io/hostname": "msl-kub02.int.na.myapp.com"
                },
                "name": "msl-kub02.int.na.myapp.com",
                "namespace": "",
                "resourceVersion": "123156",
                "selfLink": "/api/v1/nodes/msl-kub02.int.na.myapp.com",
                "uid": "084f439e-9945-11e7-bf0b-fa163e6604fc"
              },
              "spec": {
                "externalID": "msl-kub02.int.na.myapp.com"
              }
            }
          ],
          "kind": "List",
          "metadata": {
            "resourceVersion": "",
            "selfLink": ""
          }
        },
        "output": [
          {
            "apiVersion": "v1",
            "kind": "Node",
            "metadata": {
              "annotations": {
                "node.alpha.kubernetes.io/ttl": "0",
                "volumes.kubernetes.io/controller-managed-attach-detach": "true"
              },
              "creationTimestamp": "2017-09-14T12:05:42Z",
              "labels": {
                "beta.kubernetes.io/arch": "amd64",
                "beta.kubernetes.io/os": "linux",
                "kubernetes.io/hostname": "msl-kub02.int.na.myapp.com"
              },
              "name": "msl-kub02.int.na.myapp.com",
              "namespace": "",
              "resourceVersion": "123156",
              "selfLink": "/api/v1/nodes/msl-kub02.int.na.myapp.com",
              "uid": "084f439e-9945-11e7-bf0b-fa163e6604fc"
            },
            "spec": {
              "externalID": "msl-kub02.int.na.myapp.com"
            }
          }
        ]
      }
    ],
    "identifier": 46281030
  },
  {
    "context": [
      "Now I would like to add all values for every ID and create new objects with the results like this:\r\n\r\n    {\"ID\":\"A\",\"VALUE\":22,\"TYPE\":\"total\"},\r\n    {\"ID\":\"B\",\"VALUE\":60,\"TYPE\":\"total\"},\r\n    {\"ID\":\"C\",\"VALUE\":23.5,\"TYPE\":\"total\"}\r\n\r\nAdditionally, the resulting objects should be added to the initial array.",
      "Here is a solution which uses reduce to compute the totals, generate objects in the specified format and add them to the original input array:\r\n\r\n     . + [\r\n         reduce .[] as $r ({}; .[$r[\"ID\"]] += $r[\"VALUE\"])\r\n       | keys[] as $id\r\n       | {ID:$id, VALUE:.[$id], TYPE:\"total\"}\r\n     ]",
      "You can group them up by the `ID`, then aggregate them into the new objects.  Then combine that with the existing array of items.\r\n\r\n    [.[], (group_by(.ID)[] | { ID: .[0].ID, VALUE: map(.VALUE)|add, TYPE: \"total\" })]"
    ],
    "utterance": "Sum the VALUE fields for each unique ID, create a new object for each with TYPE set to \"total\", and append these objects to the original array.",
    "expressions": [
      ". + [reduce .[] as $r ({}; .[$r[\"ID\"]] += $r[\"VALUE\"]) | keys[] as $id | {ID:$id, VALUE:.[$id], TYPE:\"total\"}]",
      "[.[], (group_by(.ID)[] | { ID: .[0].ID, VALUE: map(.VALUE)|add, TYPE: \"total\" })]"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "A",
            "VALUE": 12,
            "TYPE": "single"
          },
          {
            "ID": "A",
            "VALUE": 17,
            "TYPE": "single"
          },
          {
            "ID": "A",
            "VALUE": -7,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 35,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 10,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 15,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 0,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 13,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 20.5,
            "TYPE": "single"
          }
        ],
        "output": [
          {
            "ID": "A",
            "VALUE": 12,
            "TYPE": "single"
          },
          {
            "ID": "A",
            "VALUE": 17,
            "TYPE": "single"
          },
          {
            "ID": "A",
            "VALUE": -7,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 35,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 10,
            "TYPE": "single"
          },
          {
            "ID": "B",
            "VALUE": 15,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 0,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 13,
            "TYPE": "single"
          },
          {
            "ID": "C",
            "VALUE": 20.5,
            "TYPE": "single"
          },
          {
            "ID": "A",
            "VALUE": 22,
            "TYPE": "total"
          },
          {
            "ID": "B",
            "VALUE": 60,
            "TYPE": "total"
          },
          {
            "ID": "C",
            "VALUE": 33.5,
            "TYPE": "total"
          }
        ]
      }
    ],
    "identifier": 46286977
  },
  {
    "context": [
      "I have time in milliseconds and I want to format it to time period. For example like this(not necessary exactly like this): 1d 23h 15m 13s.",
      "Here is a solution which does the calculations directly.",
      "Here is a concise but straightforward implementation of a function for converting milliseconds to a condensed \"d h m s\" string, with no rounding.",
      "$ jq -Mnr --argjson ms 1505752580000 -f filter.jq",
      "outputs",
      "17427d 16h 36m 20s",
      "$ jq -Mnr --argjson ms 1505750 -f filter.jq",
      "outputs",
      "25m 5s",
      "Example:",
      "$ jq -r -f formattime.jq",
      "1505752580000",
      "17427d 16h 36m 20s",
      "6006",
      "6s",
      "1",
      "0s"
    ],
    "utterance": "Convert a time value in milliseconds to a string showing days, hours, minutes, and seconds in the format 'Nd Nh Nm Ns'.",
    "expressions": [
      "def roundto(n):   (./n|floor)*n ;\ndef timefmt(ms):\n  def calcsecs:                             .s_to_m = (.seconds | roundto(60)) | .secs = .seconds - .s_to_m ;\n  def calcmins:     .minutes = .s_to_m/60 | .m_to_h = (.minutes | roundto(60)) | .mins = .minutes - .m_to_h ;\n  def calchrs:      .hours   = .m_to_h/60 | .h_to_d = (.hours   | roundto(24)) | .hrs  = .hours   - .h_to_d ;\n  def calcdays:     .days    = .h_to_d/24 ;\n  def fmtelt(e;u):  if e>0 then \" \\(e)\\(u)\" else \"\" end ;\n  def fmt:\n      .s = \" \\(.secs)s\"\n    | .m = fmtelt(.mins; \"m\")\n    | .h = fmtelt(.hrs; \"h\")\n    | .d = fmtelt(.days; \"d\")\n    | \"\\(.d)\\(.h)\\(.m)\\(.s)\"[1:]\n  ;\n  {seconds: (ms/1000)|floor} | calcsecs | calcmins | calchrs | calcdays | fmt\n;     \ntimefmt($ms)",
      "def formattime:\n  def f(u): if .>0 then \" \\(.)\" + u else \"\" end ;\n  # emit a stream of the remainders\n  def s: foreach (1000,60,60,24,1) as $i ([.,0];\n    .[0] as $n\n    | ($n/$i | floor) as $m\n    | [$m, $n - ($m*$i)];\n    if $i == 1 then .[0] else .[1] end);\n [s] as [$ms, $s, $m, $h, $d]\n  | {s : \" \\($s)s\",\n     m : ($m|f(\"m\")),\n     h : ($h|f(\"h\")),\n     d : ($d|f(\"d\")) }\n  | \"\\(.d)\\(.h)\\(.m)\\(.s)\"[1:]\n;\nformattime"
    ],
    "data": [
      {
        "input": 1505752580000,
        "output": "17427d 16h 36m 20s"
      },
      {
        "input": 1505750,
        "output": "25m 5s"
      },
      {
        "input": 6006,
        "output": "6s"
      },
      {
        "input": 1,
        "output": "0s"
      }
    ],
    "identifier": 46282902
  },
  {
    "context": [
      "I would like to turn this:\r\n\r\n\r\n    {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: [1,2,3,4]\r\n    }\r\n\r\ninto this\r\n\r\n    [\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 1},\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 2},\r\n    ...\r\n    ]",
      "You can use `cat ab.json|jq &#39;[{&quot;a&quot;: .a, &quot;b&quot;: .b[]}]&#39;` to get the answer.",
      "If minimizing keystrokes is the goal, then consider:\r\n\r\n    jq &#39;.+{b:.b[]}&#39; &lt;&lt;&lt; &quot;$j&quot;\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 1\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 3\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 4\r\n    }\r\n\r\nUsing `.` here ensures that all keys other than &quot;b&quot; will be preserved. By contrast, if one wants to ignore all the keys other than &quot;a&quot; and &quot;b&quot;, then one could use the jq filter:\r\n\r\n     {a,b:.b[]}\r\n\r\nTo turn the stream into an array, just wrap the expression in square brackets: [ ... ]",
      "Here is a solution:\r\n\r\n    $ jq -Mc &#39;[.b=.b[]]&#39; data.json\r\n\r\nIf `data.json` contains the sample data the output is\r\n\r\n    [{&quot;a&quot;:1,&quot;b&quot;:1},{&quot;a&quot;:1,&quot;b&quot;:2},{&quot;a&quot;:1,&quot;b&quot;:3},{&quot;a&quot;:1,&quot;b&quot;:4}]\r\n"
    ],
    "utterance": "Create an array of objects, each combining the value of a and one item from b, for all items in b.",
    "expressions": [
      "[{\"a\": .a, \"b\": .b[]}]",
      ".+{b:.b[]}",
      "[.b=.b[]]",
      "[{a,b:.b[]}]"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": [
            1,
            2,
            3,
            4
          ]
        },
        "output": [
          {
            "a": 1,
            "b": 1
          },
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 1,
            "b": 3
          },
          {
            "a": 1,
            "b": 4
          }
        ]
      }
    ],
    "identifier": 46337867
  },
  {
    "context": [
      "I have a simple JSON array:\r\n\r\n    [\r\n    \"smoke-tests\",\r\n    \"other-tests\"\r\n    ]\r\n\r\nI'd like to convert to a simple JSON:\r\n\r\n    {\"smoke-tests\": true,\r\n     \"other-tests\": true\r\n    }",
      "jq 'reduce .[] as $k ({}; .[$k]=true)' file",
      "jq '[.[] | {(.): true}] | add' <<<\"$s\"",
      ". as $in | {} | .[$in[]] = true",
      "[{(.[]):true}]|add"
    ],
    "utterance": "Convert an array of strings into an object where each string is a key with the value true.",
    "expressions": [
      "reduce .[] as $k ({}; .[$k]=true)",
      "[.[] | {(.): true}] | add",
      ". as $in | {} | .[$in[]] = true",
      "[{(.[]):true}]|add"
    ],
    "data": [
      {
        "input": [
          "smoke-tests",
          "other-tests"
        ],
        "output": {
          "smoke-tests": true,
          "other-tests": true
        }
      }
    ],
    "identifier": 46372378
  },
  {
    "context": [
      "Each one has an array of clients and I want to compare the lenght of those arrays to check if they have the same amount of customers for preventing errors.",
      "How I can compare these results? I would like the following output:",
      "In contrary case:\r\n\r\n    Missing customer test2@test2.com\r\n\r\nThe customer ID: **is the email**.",
      "[$mongo[][].client_id] as $mongo_ids\r\n| [$elastic[][].alias] as $elastic_ids\r\n| [$stripe[].data[].id] as $stripe_ids\r\n| (($mongo_ids + $elastic_ids + $stripe_ids) | unique) as $all_ids\r\n| {\"missing_from_stripe\":  ($all_ids - $stripe_ids),\r\n   \"missing_from_elastic\": ($all_ids - $elastic_ids),\r\n   \"missing_from_mongo\":   ($all_ids - $mongo_ids)}\r\n| [to_entries[] | select(.value|length > 0)] | from_entries"
    ],
    "utterance": "Find customer emails that are present in any file but missing from one or more of mongo, elastic, or stripe.",
    "expressions": [
      "jq -n \\\n  --slurpfile mongo mongo.json \\\n  --slurpfile elastic elastic.json \\\n  --slurpfile stripe stripe.json \\\n'\n  [$mongo[][].client_id] as $mongo_ids\n| [$elastic[][].alias] as $elastic_ids\n| [$stripe[].data[].id] as $stripe_ids\n| (($mongo_ids + $elastic_ids + $stripe_ids) | unique) as $all_ids\n| {\"missing_from_stripe\":  ($all_ids - $stripe_ids),\n   \"missing_from_elastic\": ($all_ids - $elastic_ids),\n   \"missing_from_mongo\":   ($all_ids - $mongo_ids)}\n| [to_entries[] | select(.value|length > 0)] | from_entries\n'"
    ],
    "data": [
      {
        "input": {
          "mongo.json": [
            {
              "_id": {
                "$oid": "59c3942baeef22b03fa573d2"
              },
              "client_id": "test@test.com",
              "name": "Windows Client"
            },
            {
              "_id": {
                "$oid": "59c3942baeef22b03fa573d2"
              },
              "client_id": "test2@test2.com",
              "name": "Linux Client"
            }
          ],
          "elastic.json": [
            {
              "alias": "test@test.com",
              "index": "index1",
              "filter": "-"
            },
            {
              "alias": "test2@test2.com",
              "index": "index2",
              "filter": "-"
            }
          ],
          "stripe.json": {
            "object": "list",
            "data": [
              {
                "id": "test@test.com",
                "object": "customer",
                "account_balance": 0,
                "created": 1505990903
              }
            ]
          }
        },
        "output": {
          "missing_from_stripe": [
            "test2@test2.com"
          ]
        }
      }
    ],
    "identifier": 46342327
  },
  {
    "context": [
      "Say I have a raw input like the following:\r\n\r\n    \"```\"\r\n    \"include <stdio.h>\"\r\n    \"...\"\r\n    \"```\"\r\n    \"''some example''\"\r\n    \"*bob\"\r\n    \"**bob\"\r\n    \"*bob\"\r\n\r\nAnd I'd like to add a blank line right before the \"*bob\":",
      "Yes, but to do so efficiently you'd effectively need jq 1.5 or higher:\r\n\r\n    foreach inputs as $line (0; \r\n      if $line == \"*bob\" then . + 1 else . end;\r\n      if . == 1 then \"\" else empty end,\r\n        $line)",
      "Here is another solution which uses the [`-s`](https://stedolan.github.io/jq/manual/#Invokingjq) (slurp) option\r\n\r\n    .[: .[[\"*bob\"]][0]] + [\"\\n\"] + .[.[[\"*bob\"]][0]:] | .[]",
      "def firstbob:  .[[\"*bob\"]][0] ;\ndef beforebob: .[: firstbob ] ;\ndef afterbob:  .[ firstbob :] ;\n\n  beforebob + [\"\\n\"] + afterbob\n| .[]"
    ],
    "utterance": "Insert an empty line immediately before the first occurrence of the line '*bob' in the input array.",
    "expressions": [
      "foreach inputs as $line (0; if $line == \"*bob\" then . + 1 else . end; if . == 1 then \"\" else empty end, $line)",
      ".[: .[[\"*bob\"]][0]] + [\"\"] + .[.[[\"*bob\"]][0]:] | .[]",
      "def firstbob:  .[[\"*bob\"]][0] ;\ndef beforebob: .[: firstbob ] ;\ndef afterbob:  .[ firstbob :] ;\nif firstbob then beforebob + [\"\"] + afterbob else . end\n| .[]"
    ],
    "data": [
      {
        "input": [
          "```",
          "include <stdio.h>",
          "...",
          "```",
          "''some example''",
          "*bob",
          "**bob",
          "*bob"
        ],
        "output": [
          "```",
          "include <stdio.h>",
          "...",
          "```",
          "''some example''",
          "",
          "*bob",
          "**bob",
          "*bob"
        ]
      }
    ],
    "identifier": 46346394
  },
  {
    "context": [
      "How can I modify jq to always drill down to BLOCK-A no matter which element in the array it is?",
      "jq -r '.files[]|select(.\"BLOCK-A\")|.[\"BLOCK-A\"].SUBBLOCKA.bkeyA'",
      "jq -r '.files|map(.\"BLOCK-A\"//empty)[].SUBBLOCKA.bkeyA'",
      "jq -r '.files[] | if (has(\"BLOCK-A\")) then .[\"BLOCK-A\"].SUBBLOCKA.bkeyA else empty end' jqtest",
      "$ jq -M '\n\ndef getfile($k): .files[] | select(keys[] == $k) | .[$k];\n\ngetfile(\"BLOCK-A\").SUBBLOCKA.bkeyA\n\n' jqtest",
      ".files[].\"BLOCK-A\"//empty|.SUBBLOCKA.bkeyA"
    ],
    "utterance": "Extract the value of bkeyA from the SUBBLOCKA object inside any BLOCK-A element in the files array, regardless of the element's position.",
    "expressions": [
      ".files[] | select(.\"BLOCK-A\") | .[\"BLOCK-A\"].SUBBLOCKA.bkeyA",
      ".files | map(.\"BLOCK-A\" // empty)[].SUBBLOCKA.bkeyA",
      ".files[] | if (has(\"BLOCK-A\")) then .[\"BLOCK-A\"].SUBBLOCKA.bkeyA else empty end",
      "def getfile($k): .files[] | select(keys[] == $k) | .[$k]; getfile(\"BLOCK-A\").SUBBLOCKA.bkeyA",
      ".files[].\"BLOCK-A\" // empty | .SUBBLOCKA.bkeyA"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "BLOCK1": {
                "SUBBLOCK1": {
                  "akey1": "avalue1",
                  "bkey1": "bvalue1",
                  "ckey1": "cvalue1"
                },
                "dkey1": "dvalue1",
                "key": "evalue1"
              }
            },
            {
              "BLOCK-2": {
                "SUBBLOCK2": {
                  "akey2": "avalue2",
                  "bkey2": "bvalue2"
                },
                "ckey2": "cvalue2",
                "key": "dvalue2"
              }
            },
            {
              "BLOCK-A": {
                "SUBBLOCKA": {
                  "akeyA": "avalueA",
                  "bkeyA": "bvalueA"
                },
                "ckeyA": "cvalueA",
                "key": "dvalueA"
              }
            }
          ],
          "NOBLOCK": "value",
          "key": "NOBLOCKvalue"
        },
        "output": "bvalueA"
      }
    ],
    "identifier": 46348981
  },
  {
    "context": [
      "Beyond that I can't access any block inside the array:",
      "Here is a function which may help in this situation.  It scans `.files` for an object with a key matching the specified key and then returns the corresponding value:",
      "def getfile($k): .files[] | select(keys[] | .==$k) | .[$k];",
      "If `jqtest` contains the sample data the command",
      "getfile(\"BLOCK1\").SUBBLOCK1.akey1",
      "Returns",
      "\"avalue1\"",
      "Another approach is to use a function to convert `.files[]` into a more useful form.  e.g.",
      "def files: reduce .files[] as $f ({}; ($f|keys[0]) as $k | .[$k] = $f[$k]) ;",
      "files",
      "which converts your input to",
      "{ \"files\": { \"BLOCK1\": { ... }, \"BLOCK-2\": { ... }, \"BLOCK-A\": { ... } }, \"NOBLOCK\": \"value\", \"key\": \"NOBLOCKvalue\" }"
    ],
    "utterance": "Access a block named 'BLOCK1' under the 'files' array and retrieve the value of 'akey1' under its 'SUBBLOCK1' subblock.",
    "expressions": [
      "def getfile($k): .files[] | select(keys[] | .==$k) | .[$k]; getfile(\"BLOCK1\").SUBBLOCK1.akey1",
      ".files[] | .BLOCK1?.SUBBLOCK1?.akey1 // empty",
      "def files: reduce .files[] as $f ({}; ($f|keys[0]) as $k | .[$k] = $f[$k]); files.BLOCK1.SUBBLOCK1.akey1"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "BLOCK1": {
                "SUBBLOCK1": {
                  "akey1": "avalue1",
                  "bkey1": "bvalue1",
                  "ckey1": "cvalue1"
                },
                "dkey1": "dvalue1",
                "key": "evalue1"
              }
            },
            {
              "BLOCK-2": {
                "SUBBLOCK2": {
                  "akey2": "avalue2",
                  "bkey2": "bvalue2"
                },
                "ckey2": "cvalue2",
                "key": "dvalue2"
              }
            },
            {
              "BLOCK-A": {
                "SUBBLOCK2": {
                  "akey2": "avalue2",
                  "bkey2": "bvalue2"
                },
                "ckey2": "cvalue2",
                "key": "dvalue2"
              }
            }
          ],
          "NOBLOCK": "value",
          "key": "NOBLOCKvalue"
        },
        "output": "avalue1"
      }
    ],
    "identifier": 46303200
  },
  {
    "context": [
      "I am trying to remove the duplicates from the following json by `id`",
      "Here is what i have tried with:\n\n    jq -r 'unique_by(.Result.name)'\nand also with `jq 'unique_by(.Result[].name)'`\n\nI am getting an error - `Cannot index array with string \"Result\"`",
      "E.g. to keep one object for each unique `{name,id}` you could use\n    \n    $ jq -M '.Result |= unique_by({name, id})' data.json"
    ],
    "utterance": "Remove duplicate items from the Result array so that only one item per unique id remains.",
    "expressions": [
      ".Result |= unique_by(.id)"
    ],
    "data": [
      {
        "input": {
          "Result": [
            {
              "name": "validation-of-art",
              "id": "12",
              "status": "passed",
              "duration": 4740302
            },
            {
              "name": "validation-of-art",
              "id": "12",
              "status": "passed",
              "duration": 272320
            },
            {
              "name": "validation-of-art",
              "id": "13",
              "status": "passed",
              "duration": 272320
            }
          ]
        },
        "output": {
          "Result": [
            {
              "name": "validation-of-art",
              "id": "12",
              "status": "passed",
              "duration": 4740302
            },
            {
              "name": "validation-of-art",
              "id": "13",
              "status": "passed",
              "duration": 272320
            }
          ]
        }
      }
    ],
    "identifier": 46397592
  },
  {
    "context": [
      "I would like to output the following:",
      "mongo_customers,customer=test@test.com",
      "mongo_customers,customer=test2@test.com",
      "jq -r '.[] | \"mongo_customers,customer=\\(.client_id)\"' mongo.json"
    ],
    "utterance": "Output one line per array element containing the prefix 'mongo_customers,customer=' followed by the value of 'client_id'.",
    "expressions": [
      ".[] | \"mongo_customers,customer=\\(.client_id)\""
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "$oid": "59c3942baeef22b03fa573d2"
            },
            "client_id": "test@test.com",
            "name": "Windows Client"
          },
          {
            "_id": {
              "$oid": "59c3942baeef22b03fa573d2"
            },
            "client_id": "test2@test2.com",
            "name": "Linux Client"
          }
        ],
        "output": [
          "mongo_customers,customer=test@test.com",
          "mongo_customers,customer=test2@test2.com"
        ]
      }
    ],
    "identifier": 46422124
  },
  {
    "context": [
      "But I want separator in between the numbers inside gpu title like this :\r\n\r\n    | version | GPU_driver | miner    | gpu  |\r\n    | ------- | ---------- | -------- | ---- |\r\n    | 1.2.3   | nvidia     | ethminer | 2/2  |\r\n    | 1.2.4   | amdgpu     | ethminer | 1/1  |",
      "simply include the character you need (slash `/`) inside the string, like this:\r\n\r\n    curl ... | jq -c '[.version,.driver,.miner,\"\\(.gpus)/\\(.miner_instance)\"] ...'",
      "Here is an example:\r\n\r\n    (\r\n      echo version,GPU_driver,miner,gpu\r\n      curl -s 'http://cd0a4a.ethosdistro.com/?json=yes' |\r\n      jq -r '\r\n        .rigs | .[] |\r\n        [ .version, .driver , .miner  , \"\\(.gpus)/\\(.miner_instance)\" ] |\r\n        @csv\r\n      '\r\n    ) |\r\n    csvlook",
      "$ curl -s http://cd0a4a.ethosdistro.com/?json=yes \\\r\n| jq -r '[\"version\", \"GPU_driver\", \"miner\", \"gpu\"],\r\n         (.rigs[] | [.version, .driver, .miner, \"\\(.gpus)/\\(.miner_instance)\"])\r\n             | @csv' \\\r\n| csvlook -I"
    ],
    "utterance": "Print each rig's version, driver, miner, and a gpu field combining gpus and miner_instance separated by a slash.",
    "expressions": [
      ".rigs | .[] | [ .version, .driver, .miner, \"\\(.gpus)/\\(.miner_instance)\" ] | @csv",
      "[\"version\", \"GPU_driver\", \"miner\", \"gpu\"], (.rigs[] | [.version, .driver, .miner, \"\\(.gpus)/\\(.miner_instance)\"]) | @csv"
    ],
    "data": [
      {
        "input": {
          "rigs": {
            "0d6b27": {
              "version": "1.2.3",
              "driver": "nvidia",
              "miner": "ethminer",
              "gpus": 2,
              "miner_instance": 2
            },
            "50dc35": {
              "version": "1.2.4",
              "driver": "amdgpu",
              "miner": "ethminer",
              "gpus": 1,
              "miner_instance": 1
            }
          }
        },
        "output": [
          "\"1.2.3\",\"nvidia\",\"ethminer\",\"2/2\"",
          "\"1.2.4\",\"amdgpu\",\"ethminer\",\"1/1\""
        ]
      }
    ],
    "identifier": 46425650
  },
  {
    "context": [
      "I need to merge an array in a series of identically structured, nested JSON files that share the same higher level keys.",
      "The goal is to create a merged file while retaining all of the existing, higher level keys and values.",
      "The following successfully merges the array but lacks the higher level keys and values in the results.",
      "Here is a solution which converts arrays to objects down to the level of services, merges with `*` and converts back to the array form.  If `file1` and `file2` contain the sample data then this command:",
      "$ jq -Mn --argfile file1 file1 --argfile file2 file2 '\n   def merge:                         # merge function\n       ($file1, $file2)               # process $file1 then $file2\n     | .account as $a                 # save .account in $a\n     | .regions[]                     # for each element of .regions\n     | .region as $r                  # save .region in $r\n     | .services[] as $s              # save each element of .services in $s\n     | {($a): {($r): $s}}             # generate object for each account,region,service\n   # | debug                          # uncomment debug here to see stream                                   \n   ;\n     reduce merge as $x ({}; . * $x)  # use '*' to recombine all the objects from merge\n\n   # | debug                          # uncomment debug here to see combined object\n\n   | keys[] as $a                     # for each key (account) of combined object\n   | {account:$a, regions:[           #  construct object with {account, regions array}\n        .[$a]                         #   for each account\n      | keys[] as $r                  #    for each key (region) of account object\n      | {region:$r, services:[        #     constuct object with {region, services array}\n           .[$r]                      #      for each region\n         | keys[] as $s               #       for each service\n         | {($s): .[$s]}              #         generate service object\n        ]}                            #      add service objects to service array\n      ]}'                             #   add region object ot regions array\n",
      "produces ...",
      "{\n  \"account\": \"123456789012\",\n  \"regions\": [\n    {\n      \"region\": \"one\",\n      \"services\": [\n        {\n          \"group_policies\": [\n            {\n              \"GroupName\": \"foo\",\n              \"PolicyNames\": [\n                \"all_foo\",\n                \"all_bar\"\n              ]\n            },\n            {\n              \"GroupName\": \"bar\",\n              \"PolicyNames\": [\n                \"all_bar\"\n              ]\n            }\n          ]\n        },\n        {\n          \"groups\": [\n            {\n              \"GroupId\": \"123456\",\n              \"GroupName\": \"foo\"\n            },\n            {\n              \"GroupId\": \"234567\",\n              \"GroupName\": \"bar\"\n            }\n          ]\n        }\n      ]\n    }\n  ]\n}"
    ],
    "utterance": "Merge two identically structured files, combining their inner arrays under all higher-level keys, so that all information is preserved in the nested structure.",
    "expressions": [
      "jq -Mn --argfile file1 file1.json --argfile file2 file2.json '\ndef merge:\n    ($file1, $file2)\n  | .account as $a\n  | .regions[]\n  | .region as $r\n  | .services[] as $s\n  | {($a): {($r): $s}};\nreduce merge as $x ({}; . * $x)\n| keys[] as $a\n| {account:$a, regions:[\n    .[$a]\n  | keys[] as $r\n  | {region:$r, services:[\n       .[$r]\n     | keys[] as $s\n     | {($s): .[$s]}\n    ]}\n  ]}'"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "account": "123456789012",
            "regions": [
              {
                "region": "one",
                "services": [
                  {
                    "groups": [
                      {
                        "GroupId": "123456",
                        "GroupName": "foo"
                      },
                      {
                        "GroupId": "234567",
                        "GroupName": "bar"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          "file2.json": {
            "account": "123456789012",
            "regions": [
              {
                "region": "one",
                "services": [
                  {
                    "group_policies": [
                      {
                        "GroupName": "foo",
                        "PolicyNames": [
                          "all_foo",
                          "all_bar"
                        ]
                      },
                      {
                        "GroupName": "bar",
                        "PolicyNames": [
                          "all_bar"
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "account": "123456789012",
          "regions": [
            {
              "region": "one",
              "services": [
                {
                  "groups": [
                    {
                      "GroupId": "123456",
                      "GroupName": "foo"
                    },
                    {
                      "GroupId": "234567",
                      "GroupName": "bar"
                    }
                  ]
                },
                {
                  "group_policies": [
                    {
                      "GroupName": "foo",
                      "PolicyNames": [
                        "all_foo",
                        "all_bar"
                      ]
                    },
                    {
                      "GroupName": "bar",
                      "PolicyNames": [
                        "all_bar"
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 46282648
  },
  {
    "context": [
      "All objects in this array should be extended by the element \"VAL\" which is calculated by multiplying RATIO with CONST. So in my case RATIO[0] (that's 0.5) is used for every object with time_CET = \"00:00:00\". RATIO[1] is used for time_CET=00:15:00 and so on.",
      "So in the end, the data.json file should look like this (on the right is the calculation logic for VAL):",
      "{ \"ID\":\"aaa\",\"time_CET\":\"00:00:00\", \"VAL\": 125}, ->0.5*250",
      "jq --argfile ratio ratio.json --argfile constants constants.json  -f program.jq data.json",
      "def getRatio(r): if .time_CET==\"00:00:00\" then r[0] elif  .time_CET==\"00:15:00\" then r[1] elif  .time_CET==\"00:30:00\" then r[2] else r[3] end ; def todict: reduce .[] as $o ({}; . + ($o | { (.ID): .CONST })); def extend(r): ($constants|todict)[.ID]  as $c | .VAL = getRatio(r) * $c ; ($ratio[0] | .RATIO) as $RATIO | map(extend($RATIO))",
      "map(.VAL = $ctable[.ID].CONST * $rtable[.time_CET])"
    ],
    "utterance": "For each object in the input, add a VAL property equal to the corresponding RATIO (matching by time_CET index) multiplied by the CONST for the same ID.",
    "expressions": [
      "def getRatio(r): if .time_CET==\"00:00:00\" then r[0] elif  .time_CET==\"00:15:00\" then r[1] elif  .time_CET==\"00:30:00\" then r[2] else r[3] end ; def todict: reduce .[] as $o ({}; . + ($o | { (.ID): .CONST })); def extend(r): ($constants|todict)[.ID]  as $c | .VAL = getRatio(r) * $c ; ($ratio[0] | .RATIO) as $RATIO | map(extend($RATIO))",
      "INDEX($constants[];.ID) as $ctable | [$data[].time_CET] | unique[] as $i | reduce [$data[].time_CET] | unique[] as $i ({}; .[$i] = $ratio[0].RATIO[length]) as $rtable | $data | map(.VAL = $ctable[.ID].CONST * $rtable[.time_CET])"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "aaa",
            "time_CET": "00:00:00"
          },
          {
            "ID": "aaa",
            "time_CET": "00:15:00"
          },
          {
            "ID": "aaa",
            "time_CET": "00:30:00"
          },
          {
            "ID": "aaa",
            "time_CET": "00:45:00"
          },
          {
            "ID": "bbb",
            "time_CET": "00:00:00"
          },
          {
            "ID": "bbb",
            "time_CET": "00:15:00"
          },
          {
            "ID": "bbb",
            "time_CET": "00:30:00"
          },
          {
            "ID": "bbb",
            "time_CET": "00:45:00"
          },
          {
            "ID": "ccc",
            "time_CET": "00:00:00"
          },
          {
            "ID": "ccc",
            "time_CET": "00:15:00"
          },
          {
            "ID": "ccc",
            "time_CET": "00:30:00"
          },
          {
            "ID": "ccc",
            "time_CET": "00:45:00"
          },
          {
            "ID": "ddd",
            "time_CET": "00:00:00"
          },
          {
            "ID": "ddd",
            "time_CET": "00:15:00"
          },
          {
            "ID": "ddd",
            "time_CET": "00:30:00"
          },
          {
            "ID": "ddd",
            "time_CET": "00:45:00"
          }
        ],
        "output": [
          {
            "ID": "aaa",
            "time_CET": "00:00:00",
            "VAL": 125
          },
          {
            "ID": "aaa",
            "time_CET": "00:15:00",
            "VAL": 175
          },
          {
            "ID": "aaa",
            "time_CET": "00:30:00",
            "VAL": 200
          },
          {
            "ID": "aaa",
            "time_CET": "00:45:00",
            "VAL": 225
          },
          {
            "ID": "bbb",
            "time_CET": "00:00:00",
            "VAL": 175
          },
          {
            "ID": "bbb",
            "time_CET": "00:15:00",
            "VAL": 245
          },
          {
            "ID": "bbb",
            "time_CET": "00:30:00",
            "VAL": 280
          },
          {
            "ID": "bbb",
            "time_CET": "00:45:00",
            "VAL": 315
          },
          {
            "ID": "ccc",
            "time_CET": "00:00:00",
            "VAL": 100
          },
          {
            "ID": "ccc",
            "time_CET": "00:15:00",
            "VAL": 140
          },
          {
            "ID": "ccc",
            "time_CET": "00:30:00",
            "VAL": 160
          },
          {
            "ID": "ccc",
            "time_CET": "00:45:00",
            "VAL": 180
          },
          {
            "ID": "ddd",
            "time_CET": "00:00:00",
            "VAL": 95
          },
          {
            "ID": "ddd",
            "time_CET": "00:15:00",
            "VAL": 133
          },
          {
            "ID": "ddd",
            "time_CET": "00:30:00",
            "VAL": 152
          },
          {
            "ID": "ddd",
            "time_CET": "00:45:00",
            "VAL": 171
          }
        ]
      }
    ],
    "identifier": 46344646
  }
]